Skip to content

Latest commit

 

History

History
735 lines (599 loc) · 55.3 KB

README.md

File metadata and controls

735 lines (599 loc) · 55.3 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.
  • 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].

Requirements

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

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.

Parameters

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

  • [conditionally required] news_type takes one of the values either recent (recent news) or recommended (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 and friends permissions.

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

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.

    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.

  2. 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 the allow_embedded_video option;
    • wall and friends are only required for the news_type option.

    Therefore, if you do not want to use some features then the relevant permissions can be omitted.

  3. 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.

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=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

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

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

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

Параметры

Основной скрипт 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.

  • [обязательный] 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 — пароль для доступа к прокси-серверу.

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

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

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

    ВАЖНОЕ: в настоящее время у новосозданных приложений требуется ввод паспортных данных или данных об организации в личном кабинете разработчика, чтобы приложение могло получать доступ к нужным правам.

    При этом старые standalone-приложения по-прежнему работают и дают возможность генерировать ключ доступа со всеми нужными правами.

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

    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.

    Если указанные параметры скрипта не будут использоваться, то соответствующие права можно убрать из ссылки.

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

  4. При первом использовании токена с 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

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