Skip to content

Latest commit

 

History

History
880 lines (724 loc) · 64.5 KB

README.md

File metadata and controls

880 lines (724 loc) · 64.5 KB

English | Russian


Generating RSS Feed for opened or closed wall of user or community (group, public page or event page) on vk.com

Features

  • 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.
  • 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].

Requirements

  • PHP>=5.3 (5.4.X, 5.5.X, 5.6.X, 7.X, 8.X 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 and cURL PHP extension is installed then script uses cURL for the requests.
  • If you want to use proxy server then
    • for HTTPS proxy: either cURL>=7.10 extension must be installed or allow_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.
  • 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

Launching

  1. Clone the repo: git clone git@github.com:Kenya-West/vkrss.git;
  2. 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
  1. 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: Successful SSL certificate installation for given domain

  1. After successful certificates installation, un-comment those lines with ### characters inside templates/default.conf.template by nano or vi/vim editors, or by executing command:
sed -i 's/### //' templates/default.conf.template
  1. Restart NGINX:
docker compose restart webserver
  1. Launch the rest:
docker compose up -d php webserver
  1. PHP server is available at 9900 port, NGINX is on 8081 for HTTP and 8082 for HTTPS respectively. These are default values, if otherwise not set in .env.

PHP server parameters

Main index.php script accepts the below GET-parameters.

id and access_token OR global_search and access_token parameters are required, another parameters are optional.

id and global_search 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 and owner_id parameters are allowed and they're identical to id.

  • [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.

  • [required] access_token is

    • 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 optionally video permissions

      If 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 or skip_ads parameters are passed then amount of posts in the result RSS feed can be less than count 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 most 2*count (count VK Donut posts + count regular posts).

    If id is passed then count 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 of count 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 most 2*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 with id,
    • or community has not enabled VK Donut feature,
    • or id belongs to some user instead of community.
  • 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 with false 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 or not_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 with true 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 when owner_only or non_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 as false), 1 (same as true). Another values are interpreted as true.

    • If owner_only is passed then allow_signed with false value doesn't include posts with signature to the RSS feed.
    • If non_owner_only or not_owner_only is passed then allow_signed with true value includes posts with signature to the RSS feed.
  • 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 the video permission then this parameter turn into false 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 and password 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 and proxy_password respectively.

NGINX server options

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

How To Get Permanent User Access Token

This authorization flow is preferred getting user access token for the server side access to the walls.

  1. Create your own standalone application here. Created app can be off after token generation because it does not matter for the API requests.

  2. Authorize necessary account on vk.com and go to the next URL

    https://oauth.vk.com/authorize?client_id=APP_ID&display=page&redirect_uri&scope=offline,video&response_type=code&v=5.131

    where replace APP_ID with application ID that's specified in the app settings.

    The permission video is only required when allow_embedded_video option is required. Therefore if you do not want use this feature then this permission can be omitted.

  3. Confirm permissions. Remember the value of GET-parameter code of the result URL in the browser address bar.

  4. Go to the URL

    https://oauth.vk.com/access_token?client_id=APP_ID&client_secret=APP_SECRET&redirect_uri&code=AUTH_CODE

    where replace APP_ID with application ID, replace APP_SECRET with secure key that's specified in the app settings, replace AUTH_CODE with code value from the previous step.

    The result JSON-response contains sought-for access token.

Bonus: created app keeps API calls statistics so you can see it.

Warning: If user terminates all sessions in him security settings then him access token becomes invalid; in that case, user must create new access token repeating steps 2-4.

Usage Examples

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=-1&count=100&include=(new|wall|\d+)&access_token=XXXXXXXXX
index.php?global_search=query&count=300&access_token=XXXXXXXXX # search posts that contains 'query'
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

or the same for NGINX server:

api/vkrss/index.php?id=apiclub&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=-1&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=id1&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=club1&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=club1&disable_html&vkrss_access_token=YYYYYYYYY   # no HTML formatting in RSS item descriptions
api/vkrss/index.php?id=apiclub&count=100&include=newsfeed&vkrss_access_token=YYYYYYYYY   # feed contains only posts with substring 'newsfeed'
api/vkrss/index.php?id=apiclub&count=100&exclude=newsfeed&vkrss_access_token=YYYYYYYYY   # feed contains only posts without substring 'newsfeed'
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&proxy_type=https&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=apiclub&proxy=https%3A%2F%2Flocalhost:8080&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=club1&owner_only&vkrss_access_token=YYYYYYYYY   # feed contains only posts by community
api/vkrss/index.php?id=club1&owner_only&allow_signed=false&vkrss_access_token=YYYYYYYYY   # feed contains only posts by community
                                                                          # that's without signature
api/vkrss/index.php?id=club1&non_owner_only&vkrss_access_token=YYYYYYYYY   # feed contains only posts by users
api/vkrss/index.php?id=club1&non_owner_only&allow_signed&vkrss_access_token=YYYYYYYYY   # feed contains only posts by users
                                                                        # and community posts with signature
api/vkrss/index.php?id=-1&count=100&include=(new|wall|\d+)&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?global_search=query&count=300&vkrss_access_token=YYYYYYYYY # search posts that contains 'query'
api/vkrss/index.php?id=club1&allow_embedded_video&vkrss_access_token=YYYYYYYYY   # embed playable videos into RSS items' description
api/vkrss/index.php?id=-1&count=30&repost_delimiter=<hr><hr>Written by {author}:&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=pitertransport&donut&vkrss_access_token=YYYYYYYYY  # RSs feed contains VK Donut posts and regular posts

Note: one parameter contains special characters in the last example, so URL-encoding can be required for the direct call: index.php?id=-1&count=100&include=(new%7Cwall%7C%5Cd%2B)&access_token=XXXXXXXXX

Troubleshooting

  • 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 like date_default_timezone_set('UTC'); to the start of the index.php script (before require_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 or index.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 with id,
    • or community has not enabled VK Donut feature,
    • or id belongs to some user instead of community.

Генерация 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.
  • Свой (под)домен и A-запись на IP-адрес сервера, в котором будет запущен данный репозиторий.

В случае каких-либо проблем вместо RSS-ленты выдается страница с HTTP-статусом, отличным от 200, и с описанием проблемы в HTTP-заголовке и теле страницы, а также создаётся запись в журнале ошибок сервера или интерпретатора.
Посмотреть логи PHP-сервера можно будет командой (последние 50 записей):

docker compose logs -t -n 50 php

Инструкция по запуску

  1. Клонируйте репозиторий: git clone git@github.com:Kenya-West/vkrss.git;
  2. Заполните файл .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
  1. Запустите certbot для получения SSL-сертификатов:
docker compose up -d certbot webserver

В логах по команде docker compose logs certbot должно быть сообщение об успешном получении сертификатов: Успешная установка сертификата для домена

  1. После успешной установки сертификатов раскомментируйте строки, начинающиеся с тройных ### в файле templates/default.conf.template редактором nano или vi/vim, либо командой:
sed -i 's/### //' templates/default.conf.template
  1. Перезапустите NGINX:
docker compose restart webserver
  1. Запустите остальное:
docker compose up -d php
  1. По умолчанию сервер PHP доступен на порте 9900, сервер NGINX на 8081 для HTTP и 8082 для HTTPS, если вы не указали иное в файле .env.

Параметры сервера PHP

Основной скрипт index.php принимает следующие GET-параметры.

Пара параметров id и access_token ИЛИ global_search и access_token обязательна, остальные параметры необязательны.

Нельзя одновременно использовать параметры id и global_search.

  • [условно обязательный] 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 — произвольный текстовый глобальный поисковый запрос, по которому с помощью внутренних алгоритмов ВКонтакте ищутся записи со всех открытых стен, опубликованные владельцем профиля пользователя или от имени сообщества. Результаты поиска аналогичны результатам на этой поисковой странице.

  • [обязательный] access_token

    • Либо сервисный ключ доступа, который указан в настройках приложения (создать собственное 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-лента генерируется для стены пользователя, а не сообщества.
  • 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 — пароль для доступа к прокси-серверу.

Параметры сервера NGINX

Параллельно с сервером 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

Как получить бессрочный токен для доступа к стенам, которые доступны своему профилю

Для серверного доступа предпочтительна такая схема:

  1. Создать собственное standalone-приложение по этой ссылке. По желанию после генерации ключей в настройках приложения можно изменить состояние на «Приложение отключено» — это никак не помешает генерации RSS-ленты.

  2. После авторизации под нужным профилем пройти по ссылке:

    https://oauth.vk.com/authorize?client_id=APP_ID&display=page&redirect_uri&scope=offline,video&response_type=code&v=5.131

    где вместо APP_ID подставить ID созданного приложения — его можно увидеть, например, в настройках приложения.

    Разрешение video необходимо лишь в случае включения параметра allow_embedded_video, поэтому если эта функциональность не будет использоваться, то можно его убрать.

  3. Подтвердить права. В результате в адресной строке будет GET-параметр code.

  4. Пройти по ссылке:

    https://oauth.vk.com/access_token?client_id=APP_ID&client_secret=APP_SECRET&redirect_uri&code=AUTH_CODE

    где APP_ID — ID созданного приложения, APP_SECRET — защищенный ключ приложения (можно увидеть в настройках приложения), AUTH_CODE — значение параметра code из предыдущего шага.

    В результате будет выдан JSON-отклик с искомым access_token — именно это значение и следует использовать в качестве GET-параметра скрипта, генерирующего RSS-ленту.

  5. При первом использовании токена с 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=-1&count=100&include=(рекомендуем|приглашаем|\d+)&access_token=XXXXXXXXX
index.php?global_search=запрос&count=300&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 ленту добавляются записи для донов

либо аналогичные для сервера с NGINX:

api/vkrss/index.php?id=apiclub&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=-1&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=id1&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=club1&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=club1&disable_html&vkrss_access_token=YYYYYYYYY   # в данных RSS-ленты отсутстуют HTML-сущности
api/vkrss/index.php?id=apiclub&count=100&include=рекомендуем&vkrss_access_token=YYYYYYYYY   # выводятся только записи со словом 'рекомендуем'
api/vkrss/index.php?id=apiclub&count=100&exclude=рекомендуем&vkrss_access_token=YYYYYYYYY   # выводятся только записи без слова 'рекомендуем'
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&proxy_type=https&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=apiclub&proxy=https%3A%2F%2Flocalhost:8080&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=club1&owner_only&vkrss_access_token=YYYYYYYYY   # выводятся только записи от имени сообщества
api/vkrss/index.php?id=club1&owner_only&allow_signed=false&vkrss_access_token=YYYYYYYYY   # выводятся только записи от имени сообщества,
                                                                          # у которых нет подписи
api/vkrss/index.php?id=club1&non_owner_only&vkrss_access_token=YYYYYYYYY   # выводятся только записи от пользователей (не от имени сообщества)
api/vkrss/index.php?id=club1&non_owner_only&allow_signed&vkrss_access_token=YYYYYYYYY   # выводятся только записи от имени сообщества,
                                                                        # у которых есть подпись, и записи от пользователей
api/vkrss/index.php?id=-1&count=100&include=(рекомендуем|приглашаем|\d+)&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?global_search=запрос&count=300&vkrss_access_token=YYYYYYYYY # поиск записей, содержащих слово "запрос"
api/vkrss/index.php?id=club1&allow_embedded_video&vkrss_access_token=YYYYYYYYY   # встраивает проигрываемые видеозаписи в описание записи
api/vkrss/index.php?id=-1&count=30&repost_delimiter=<hr><hr>{author} пишет:&vkrss_access_token=YYYYYYYYY
api/vkrss/index.php?id=pitertransport&donut&vkrss_access_token=YYYYYYYYY  # Помимо обычных записей, в RSS ленту добавляются записи для донов

Примечание: в последнем примере при таком вызове напрямую через GET-параметры может потребоваться URL-кодирование символов: 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-лента генерируется для стены пользователя, а не сообщества.