rovereto / yandex-metrika
API Яндекс.Метрики
Requires
- php: ^7.2 || ^8.0
- guzzlehttp/guzzle: ^6.0|^7.0
- illuminate/support: ^5.0|^6.0|^7.0|^8.0|^9.0
- jms/serializer: ^1.8|^2.0|^3.0
This package is auto-updated.
Last update: 2024-10-29 06:25:33 UTC
README
Пакет предназначен для работы с Logs API и API отчётов Яндекс Метрики.
- Logs API позволяет получать неагрегированные данные, собираемые Яндекс.Метрикой. Данный API предназначен для пользователей сервиса, которые хотят самостоятельно обрабатывать статистические данные и использовать их для решения уникальных аналитических задач.
- API отчетов API отчетов позволяет получать информацию о статистике посещений сайта и другие данные, не используя интерфейс Яндекс.Метрики.
Собраны и переработаны два репозитория, которые давно не обновлялись и не работают в новых версиях Laravel.
- для Logs API используется Logs API Яндекс.Метрики
- для API отчётов используется Yandex Metrika Laravel 5 Package
Установка
Минимальные требования — PHP 7.2+.
- Установка пакета с помощью Composer:
composer require rovereto/yandex-metrika
Для Laravel <5.5
a. Добавьте сервис провайдера в файл app/config/app.php:
'providers' => [ ... Rovereto\YandexMetrika\Providers\YandexMetrikaProvider::class, ... ]
b. Добавьте алиас для фасада в файл app/config/app.php:
'aliases' => [ ... 'YandexMetrikaApi' => Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi::class, ... ]
- Публикация файла настроек (config/yandex-metrika-api.php):
php artisan vendor:publish --provider="Rovereto\YandexMetrika\Providers\YandexMetrikaProvider"
Авторизация в API Яндекс Метрики
Для использования API Яндекс.Метрики необходимо получить авторизационный токен через OAuth-сервер Яндекса (подробнее).
Чтобы начать пользоваться OAuth протоколом, необходимо:
- Зарегистрировать приложение на Яндекс.OAuth.
Зарегистрировать приложение можно на странице Создание приложения. Для каждого приложения обязательно указать только название и доступы. Но чем больше информации о приложении вы предоставите, тем легче пользователям будет понять, кому именно они разрешают доступ к своему аккаунту.
При регистрации выберите права доступа.
Все приложения, которые вы создали, перечислены в списке ваших приложений.
-
Копируем ID приложения и заходим на Яндекс под той учетной записью, от имени которой будет работать приложение.
-
Переходим по URL:
https://oauth.yandex.ru/authorize?response_type=token&client_id=<Идентификатор приложения>
-
Приложение запросит разрешение на доступ, нажимаем «Разрешить»
-
Заносим полученный токен в файл конфигурации пакета config/yandex-metrika-api.php. Там же заполняем идентификатор счётчика.
return [ 'token' => env('YANDEX_METRIKA_API_TOKEN', '<Token>'), 'counter_id' => env('YANDEX_METRIKA_API_COUNTER_ID', <Id счётчика>), ... ];
Или прописываем токен и идентификатор счётчика в файле .ENV
YANDEX_METRIKA_API_TOKEN="<Token>"
YANDEX_METRIKA_API_COUNTER_ID=<Id счётчика>
Использование
Два варианта подключения класса API Яндекс Метрики
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi;
или
use YandexMetrikaApi;
Использование нескольких счетчиков.
Если вам нужно получать данные от разных счетчиков
YandexMetrikaApi::setCounter($token, $counterId, $cacheLifetime)->имя_метода(); // Например YandexMetrikaApi::setCounter($token, $counterId, $cacheLifetime)->getVisitsViewsUsers(); // $token и $counterId - обязательные параметры, // параметр $cacheLifetime - необязателен (если не передан то будет использоваться из настроек)
Для смены только идентификатора счётчика
YandexMetrikaApi::setCounterId($counterId)->имя_метода(); // Например YandexMetrikaApi::setCounterId($counterId)->getVisitsViewsUsers();
Использование API отчётов Яндекс Метрики
Запросы кэшируются, время жизни кэша указывается в конфигурационном файле.
Ошибки возникающие при запросе данных пишутся в лог с названием storage/logs/yandex-metrika-api.log с ежедневной ротацией
Результат запроса - объект класса Rovereto\YandexMetrika\Responses\MetrikaResponse
Для обработки полученных данных есть дополнительные методы, которые делают данные более удобными для применения.
Для их использования используйте метод adapt()
Не у всех методов для получения данных есть метод для обработки.
Получаем кол-во: визитов, просмотров, уникальных посетителей по дням
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getVisitsViewsUsers(); //По умолчанию - за последние 30 дней //Пример YandexMetrikaApi::getVisitsViewsUsers(10); //За последние 10 дней //За период YandexMetrikaApi::getVisitsViewsUsersForPeriod(DateTime $startDate, DateTime $endDate) //За указанный период //Обработка полученных данных для построения графика Highcharts › Basic line YandexMetrikaApi::getVisitsViewsUsers()->adapt();
Самые просматриваемые страницы
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getTopPageViews(); //По умолчанию за последние 30 дней, количество результатов - 10 //Пример YandexMetrikaApi::getTopPageViews(10, 50); //За последние 10 дней, максимум 50 результатов //За период - по умолчанию максимум 10 результатов YandexMetrikaApi::getTopPageViewsForPeriod(DateTime $startDate, DateTime $endDate, $limit = 10) //Обработка полученных данных YandexMetrikaApi::getTopPageViews()->adapt();
Отчет "Источники - Сводка"
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getSourceSummary(); //По умолчанию за последние 30 дней //Пример YandexMetrikaApi::getSourceSummary(7); //За последние 10 дней //За период YandexMetrikaApi::getSourcesSummaryForPeriod(DateTime $startDate, DateTime $endDate) //Обработка полученных данных YandexMetrikaApi::getSourcesSummary()->adapt();
Отчет "Источники - Поисковые фразы"
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getSourcesSearchPhrases(); //По умолчанию за последние 30 дней, количество результатов - 10 //Пример YandexMetrikaApi::getSourcesSearchPhrases(15, 20); //За последние 15 дней, максимум 20 результатов //За период - по умолчанию максимум - 10 результатов YandexMetrikaApi::getSourcesSearchPhrasesForPeriod(DateTime $startDate, DateTime $endDate, $limit = 10) //Обработка полученных данных YandexMetrikaApi::getSourcesSearchPhrases()->adapt();
Отчет "Технологии - Браузеры"
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getTechPlatforms(); //По умолчанию за последние 30 дней, макс количество результатов - 10 //Пример YandexMetrikaApi::getTechPlatforms(12, 5); //За последние 12 дней, максимум 5 результатов //За период - по умолчанию максимум - 10 результатов YandexMetrikaApi::getTechPlatformsForPeriod(DateTime $startDate, DateTime $endDate, $limit = 10) //Обработка полученных данных YandexMetrikaApi::getTechPlatforms()->adapt();
Количество визитов и посетителей с учетом поисковых систем
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getVisitsUsersSearchEngine(); //По умолчанию за последние 30 дней, макс количество результатов - 10 //Пример YandexMetrikaApi::getVisitsUsersSearchEngine(24, 60); //За последние 24 дня, максимум 60 результатов //За период - по умолчанию максимум - 10 результатов YandexMetrikaApi::getVisitsUsersSearchEngineForPeriod(DateTime $startDate, DateTime $endDate, $limit = 10) //Обработка полученных данных YandexMetrikaApi::getVisitsUsersSearchEngine()->adapt();
Количество визитов с заданной глубиной просмотра
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getVisitsViewsPageDepth(); //По умолчанию за последние 30 дней, количество просмотренных страниц - 5 //Пример YandexMetrikaApi::getVisitsViewsPageDepth(14, 30); //За последние 14 дней, макс количество результатов - 30 //За период - по умолчанию - 5 страниц YandexMetrikaApi::getVisitsViewsPageDepthForPeriod(DateTime $startDate, DateTime $endDate, $pages = 5) //Обработка полученных данных YandexMetrikaApi::getVisitsViewsPageDepth()->adapt();
Отчеты о посещаемости сайта с распределением по странам и регионам
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getGeoCountry(); //По умолчанию за последние 7 дней, макс количество результатов - 100 //Пример YandexMetrikaApi::getGeoCountry(12, 30); //За последние 12 дней, макс количество результатов - 30 //За период - по умолчанию максимум - 100 результатов YandexMetrikaApi::getGeoCountryForPeriod(DateTime $startDate, DateTime $endDate, $limit = 100) //Обработка полученных данных для построения графика Highcharts.js > Pie with drilldown YandexMetrikaApi::getGeoCountry()->adapt()();
Отчеты о посещаемости сайта с распределением по областям и городам
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; YandexMetrikaApi::getGeoArea(); //По умолчанию за последние 7 дней, макс количество результатов - 100, Страна - Россия (id-225) //Пример YandexMetrikaApi::getGeoArea(12, 30, 149); //За последние 12 дней, макс количество результатов - 30, страна - Белоруссия //За период YandexMetrikaApi::getGeoAreaForPeriod(DateTime $startDate, DateTime $endDate, $limit = 100, $countryId = 225) //Обработка полученных данных для построения графика Highcharts.js > Pie with drilldown YandexMetrikaApi::getGeoArea()->adapt()();
Для методов getGeoCountry() и getGeoArea() - метод обработки данных общий - adaptGeoPie()
Произвольный запрос к Api отчётов Yandex Metrika
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; //Параметры запроса $params = [ 'date1' => Carbon::today()->subDays(10), //Начальная дата 'date2' => Carbon::today(), //Конечная дата 'metrics' => 'ym:s:visits', 'filters' => 'ym:s:pageViews>5' ]; //Запрос YandexMetrikaApi::getMetrikaResponse($params);
Использование Log API Яндекс Метрики
Оценка возможности создания запроса
Оценивает возможность создания запроса логов по его примерному размеру.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getCapabilityResponse( Carbon::parse('2022-01-01'), Carbon::parse('2022-04-30'), [ 'ym:pv:watchID', 'ym:pv:counterID', 'ym:pv:date', 'ym:pv:dateTime', 'ym:pv:title', 'ym:pv:URL', 'ym:pv:referer', ], 'hits');
Создание запроса логов
Создает запрос логов.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getCreateResponse( Carbon::parse('2022-01-01'), Carbon::parse('2022-04-30'), [ 'ym:pv:watchID', 'ym:pv:counterID', 'ym:pv:date', 'ym:pv:dateTime', 'ym:pv:title', 'ym:pv:URL', 'ym:pv:referer', ], 'hits');
Отмена не обработанного запроса логов
Отменяет еще не обработанный запрос логов.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getCancelResponse($requestId);
Информация о запросе логов
Возвращает информацию о запросе логов.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getInformationResponse($requestId);
Загрузка части подготовленных логов обработанного запроса
Загружает часть подготовленных логов обработанного запроса.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getDownloadResponse($requestId, $partNumber); if ($response instanceof \GuzzleHttp\Psr7\Stream) { while (!$response->eof()) { echo $response->read(1024); } }
Очистка подготовленных для загрузки логов обработанного запроса
Очищает подготовленные для загрузки логи обработанного запроса.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getCleanResponse($requestId);
Список запросов логов
Возвращает список запросов логов.
use Rovereto\YandexMetrika\Support\Facades\YandexMetrikaApi; $response = YandexMetrikaApi::getLogListResponse();
Contributing
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
Versioning
We use Semantic Versioning for versioning. For the versions available, see the tags on this repository.
Changelog
Refer to the Changelog for a full history of the project.
Support
The following support channels are available at your fingertips:
Author
- Alexander Ilyutkin Ilyutkin
- Volga Volga
- Alex Manekin Alex Manekin
See also the list of contributors who participated in this project.
License
This project is licensed under the The MIT License (MIT) Massachusetts Institute of Technology License - see the LICENSE.md file for details