{"id":15579275,"url":"https://github.com/andrey-tech/bizon365-api-php","last_synced_at":"2025-03-29T07:44:56.568Z","repository":{"id":56948068,"uuid":"272434818","full_name":"andrey-tech/bizon365-api-php","owner":"andrey-tech","description":"Обертка на PHP7+ для работы с REST API v1 сервиса Бизон 365 с троттлингом запросов и логированием в файл.","archived":false,"fork":false,"pushed_at":"2021-02-07T16:40:13.000Z","size":174,"stargazers_count":1,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-02-03T21:46:05.676Z","etag":null,"topics":["api","api-wrapper","bizon","bizon365","logging","php","throttling"],"latest_commit_sha":null,"homepage":"","language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/andrey-tech.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2020-06-15T12:37:39.000Z","updated_at":"2022-01-24T16:13:00.000Z","dependencies_parsed_at":"2022-08-21T03:10:17.435Z","dependency_job_id":null,"html_url":"https://github.com/andrey-tech/bizon365-api-php","commit_stats":null,"previous_names":[],"tags_count":4,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fbizon365-api-php","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fbizon365-api-php/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fbizon365-api-php/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fbizon365-api-php/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/andrey-tech","download_url":"https://codeload.github.com/andrey-tech/bizon365-api-php/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":246156028,"owners_count":20732359,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api","api-wrapper","bizon","bizon365","logging","php","throttling"],"created_at":"2024-10-02T19:14:19.439Z","updated_at":"2025-03-29T07:44:56.552Z","avatar_url":"https://github.com/andrey-tech.png","language":"PHP","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Bizon365 API PHP Wrapper\n\n![Bizon365 logo](./assets/bizon365-logo.png)  \n[![Latest Stable Version](https://poser.pugx.org/andrey-tech/bizon365-api-php/v)](https://packagist.org/packages/andrey-tech/bizon365-api-php)\n[![Total Downloads](https://poser.pugx.org/andrey-tech/bizon365-api-php/downloads)](https://packagist.org/packages/andrey-tech/bizon365-api-php)\n[![License](https://poser.pugx.org/andrey-tech/bizon365-api-php/license)](https://packagist.org/packages/andrey-tech/bizon365-api-php)\n\n\nОбертка на PHP7+ для работы с [REST API v1](https://blog.bizon365.ru/api/v1/) сервиса Бизон 365 c троттлингом запросов к API и логированием в файл.\n\n## Содержание\n\n\u003c!-- MarkdownTOC levels=\"1,2,3,4,5,6\" autoanchor=\"true\" autolink=\"true\" --\u003e\n\n- [Требования](#%D0%A2%D1%80%D0%B5%D0%B1%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F)\n- [Установка](#%D0%A3%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BA%D0%B0)\n- [Класс `Bizon365API`](#%D0%9A%D0%BB%D0%B0%D1%81%D1%81-bizon365api)\n    - [Общие методы класса](#%D0%9E%D0%B1%D1%89%D0%B8%D0%B5-%D0%BC%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%BA%D0%BB%D0%B0%D1%81%D1%81%D0%B0)\n    - [Дополнительные параметры](#%D0%94%D0%BE%D0%BF%D0%BE%D0%BB%D0%BD%D0%B8%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D1%8B%D0%B5-%D0%BF%D0%B0%D1%80%D0%B0%D0%BC%D0%B5%D1%82%D1%80%D1%8B)\n    - [Методы для получения отчетов по вебинарам](#%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%B4%D0%BB%D1%8F-%D0%BF%D0%BE%D0%BB%D1%83%D1%87%D0%B5%D0%BD%D0%B8%D1%8F-%D0%BE%D1%82%D1%87%D0%B5%D1%82%D0%BE%D0%B2-%D0%BF%D0%BE-%D0%B2%D0%B5%D0%B1%D0%B8%D0%BD%D0%B0%D1%80%D0%B0%D0%BC)\n        - [Примеры](#%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B)\n    - [Методы для работы с подписчиками](#%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%B4%D0%BB%D1%8F-%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D1%8B-%D1%81-%D0%BF%D0%BE%D0%B4%D0%BF%D0%B8%D1%81%D1%87%D0%B8%D0%BA%D0%B0%D0%BC%D0%B8)\n        - [Примеры](#%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B-1)\n- [Вспомогательные классы](#%D0%92%D1%81%D0%BF%D0%BE%D0%BC%D0%BE%D0%B3%D0%B0%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D1%8B%D0%B5-%D0%BA%D0%BB%D0%B0%D1%81%D1%81%D1%8B)\n    - [Класс `HTTP`](#%D0%9A%D0%BB%D0%B0%D1%81%D1%81-http)\n        - [Примеры](#%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B-2)\n    - [Класс `DebugLogger`](#%D0%9A%D0%BB%D0%B0%D1%81%D1%81-debuglogger)\n        - [Методы класса](#%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%BA%D0%BB%D0%B0%D1%81%D1%81%D0%B0)\n        - [Дополнительные параметры](#%D0%94%D0%BE%D0%BF%D0%BE%D0%BB%D0%BD%D0%B8%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D1%8B%D0%B5-%D0%BF%D0%B0%D1%80%D0%B0%D0%BC%D0%B5%D1%82%D1%80%D1%8B-1)\n        - [Примеры](#%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B-3)\n            - [Формат заголовков лога](#%D0%A4%D0%BE%D1%80%D0%BC%D0%B0%D1%82-%D0%B7%D0%B0%D0%B3%D0%BE%D0%BB%D0%BE%D0%B2%D0%BA%D0%BE%D0%B2-%D0%BB%D0%BE%D0%B3%D0%B0)\n- [Автор](#%D0%90%D0%B2%D1%82%D0%BE%D1%80)\n- [Лицензия](#%D0%9B%D0%B8%D1%86%D0%B5%D0%BD%D0%B7%D0%B8%D1%8F)\n\n\u003c!-- /MarkdownTOC --\u003e\n\n\u003ca id=\"%D0%A2%D1%80%D0%B5%D0%B1%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F\"\u003e\u003c/a\u003e\n## Требования\n\n- PHP \u003e= 7.0;\n- класс [`HTTP`](https://github.com/andrey-tech/http-client-php) \u003e= 3.0 - НТТР(S) клиент с троттлингом запросов, поддержкой маркера BOM в теле сообщения формата JSON и выводом отладочной информации о запросах и ответах в STDOUT;\n- класс [`DebugLogger`](https://github.com/andrey-tech/debug-logger-php) \u003e= 2.0 - логгер, сохраняющий отладочную информацию в файл вместе с данными об объеме используемой оперативной памяти и прошедшем времени;\n- произвольный автозагрузчик классов, реализующий стандарт [PSR-4](https://www.php-fig.org/psr/psr-4/).\n\n\u003ca id=\"%D0%A3%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BA%D0%B0\"\u003e\u003c/a\u003e\n## Установка\n\nУстановка через composer:\n```\n$ composer require andrey-tech/bizon365-api-php:\"^2.2\"\n```\n\nили добавить\n\n```\n\"andrey-tech/bizon365-api-php\": \"^2.2\"\n```\n\nв секцию require файла composer.json.\n\n\u003ca id=\"%D0%9A%D0%BB%D0%B0%D1%81%D1%81-bizon365api\"\u003e\u003c/a\u003e\n## Класс `Bizon365API`\n\nДля работы с REST API v1 сервиса Бизон 365 используется класс `\\App\\Bizon365\\Bizon365API`.  \nПри возникновении ошибок выбрасывается исключение класса `\\App\\Bizon365\\Bizon365APIException`.  \n\nВ настоящее время в классе реализованы:\n\n- [методы работы со страницами регистрации и подписчиками вебинаров](https://blog.bizon365.ru/api/v1/webinars/subpages/);\n- [методы для получения отчетов по проведенным вебинарам и автовебинарам](https://blog.bizon365.ru/api/v1/webinars/reports/).\n\nПоддерживается [оба способа авторизации](https://blog.bizon365.ru/api/v1/avtorizatsiya/) в сервисе Бизон 365:\n\n- предварительная авторизация с получением cookie;\n- авторизация через токен пользователя.\n\n\u003ca id=\"%D0%9E%D0%B1%D1%89%D0%B8%D0%B5-%D0%BC%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%BA%D0%BB%D0%B0%D1%81%D1%81%D0%B0\"\u003e\u003c/a\u003e\n### Общие методы класса\n\n- `__construct(string $authToken = null)`  \n    Конструктор класса.\n    + `$authToken` - токен авторизации (для авторизации посредством токена пользователя).\n- `auth(string $username, string $password) :array`  \n    Выполняет предварительную авторизация с получением cookie и возвращает ответ от API.\n    + `$username` - имя пользователя;\n    + `$password` - пароль пользователя.\n- `logout() :array`  \n    Выполняет выход из системы и возвращает ответ от API.\n- `setLogger($logger)` Устанавливает объект класса, выполняющего логирование отладочной информации в файл.\n    + объект класса, реализующего интерфейс `\\App\\DebugLogger\\DebugLoggerInterface`.\n\n\u003ca id=\"%D0%94%D0%BE%D0%BF%D0%BE%D0%BB%D0%BD%D0%B8%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D1%8B%D0%B5-%D0%BF%D0%B0%D1%80%D0%B0%D0%BC%D0%B5%D1%82%D1%80%D1%8B\"\u003e\u003c/a\u003e\n### Дополнительные параметры\n\nДополнительные параметры настройки доступны через публичные свойства класса `\\App\\Bizon365\\Bizon365API`:\n\nНестатическое свойство  | По умолчанию       | Описание\n----------------------- | ------------------ | --------\n`$logger`               | null               | Хранит объект класса `\\App\\DebugLogger\\DebugLogger`, выполняющего логирование запросов и ответов к API в файл. Если null, то логирование не выполняется.\n`$http`                 | `\\App\\HTTP\\HTTP`   | Хранит объект класса `\\App\\HTTP\\HTTP`, отправляющего запросы к API\n\n\u003ca id=\"%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%B4%D0%BB%D1%8F-%D0%BF%D0%BE%D0%BB%D1%83%D1%87%D0%B5%D0%BD%D0%B8%D1%8F-%D0%BE%D1%82%D1%87%D0%B5%D1%82%D0%BE%D0%B2-%D0%BF%D0%BE-%D0%B2%D0%B5%D0%B1%D0%B8%D0%BD%D0%B0%D1%80%D0%B0%D0%BC\"\u003e\u003c/a\u003e\n### Методы для получения отчетов по вебинарам\n\nМетоды для получения отчетов по проведенным вебинарам и автовебинарам находятся в трейте `\\App\\Bizon365\\WebinarViewers`:\n\n- `getWebinarList(int $skip = 0, int $limit = 100, bool $liveWebinars = true, bool $autoWebinars = true) :array`  \n    Возвращает список доступных отчетов по вебинарам.\n     + `$skip` - пропустить указанное число записей;\n     + `$limit` - ограничить количество записей (не более 100);\n     + `$liveWebinars` - искать среди живых вебинаров;\n     + `$autoWebinars` - искать среди автовебинаров.\n- `getAllWebinarList(int $skip = 0, int $limit = 100, bool $liveWebinars = true, bool $autoWebinars = true) :array`  \n    Возвращает список *всех* доступных отчетов по вебинарам.\n     + `$skip` - пропустить указанное число записей;\n     + `$limit` - количество записей в одном ответе от API (не более 100);\n     + `$liveWebinars` - искать среди живых вебинаров;\n     + `$autoWebinars` - искать среди автовебинаров.\n- `getWebinarViewers(string $webinarId, int $skip = 0, int $limit = 1000) :array`  \n    Возвращает список зрителей вебинара.\n     + `$webinarId` - ID вебинара;\n     + `$skip` - пропустить указанное число записей;\n     + `$limit` - ограничить количество записей (не более 1000);\n - `getAllWebinarViewers(string $webinarId, int $skip = 0, int $limit = 1000) :array`  \n    Возвращает список *всех* зрителей вебинара.\n     + `$webinarId` - ID вебинара;\n     + `$skip` - пропустить указанное число записей;\n     + `$limit` - количество записей в одном ответе от API (не более 100);\n\n\u003ca id=\"%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B\"\u003e\u003c/a\u003e\n#### Примеры\n\n```php\nuse App\\Bizon365\\{Bizon365API, Bizon365APIException};\n\ntry {\n    $bizon365 = new Bizon365API();\n\n    // Выполняем предварительную авторизацию\n    $bizon365-\u003eauth('ivan@example.com', 'klfi89309gkds');\n\n    // Получаем список из 100 доступных отчетов по вебинарам\n    $webinars = $bizon365-\u003egetWebinarList($skip = 0, $limit = 100);\n    print_r($webinars);\n\n    // Получаем список всех доступных отчетов по вебинарам\n    $webinars = $bizon365-\u003egetAllWebinarList();\n    print_r($webinars);\n\n    // Получаем список из 100 зрителей первого вебинара\n    $webinarId = $webinars[0]['webinarId'];\n    $viewers = $bizon365-\u003egetWebinarViewers($webinarId, $skip = 0, $limit = 100);\n    print_r($viewers);\n\n    // Получаем список всех зрителей первого вебинара\n    $viewers = $bizon365-\u003egetAllWebinarViewers($webinarId);\n    print_r($viewers);\n\n    // Выполняем выход\n    $bizon365-\u003elogout();\n\n} catch (Bizon365APIException $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n} catch (Exception $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n}\n```\n\n\n\u003ca id=\"%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%B4%D0%BB%D1%8F-%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D1%8B-%D1%81-%D0%BF%D0%BE%D0%B4%D0%BF%D0%B8%D1%81%D1%87%D0%B8%D0%BA%D0%B0%D0%BC%D0%B8\"\u003e\u003c/a\u003e\n### Методы для работы с подписчиками\n\nМетоды для работы со страницами регистрации и подписчиками находятся в трейте `\\App\\Bizon365\\WebinarSubsribers`:\n\n- `getWebinarSubpages(int $skip = 0, int $limit = 50) :array`  \n    Возвращает список страниц регистрации и их рассылок.\n    + `$skip` - пропустить указанное число записей;\n    + `$limit` - ограничить количество записей (не более 50).\n- `getAllWebinarSubpages(int $skip = 0, int $limit = 50) :array`  \n    Возвращает список *всех* страниц регистрации и их рассылок.\n    + `$skip` - пропустить указанное число записей;\n    + `$limit` - количество записей в одном ответе от API (не более 50).\n-   `getWebinarSubscribers(string $pageId, int $skip = 0, int $limit = 1000, string $webinarTimeMin = null, string $webinarTimeMax = null, string $registeredTimeMin = null, string $registeredTimeMax = null, string $url_marker = null) :array`  \n    Возвращает список подписчиков для заданной страницы регистрации.\n    + `$pageId` - ID страницы регистрации;\n    + `$skip` - пропустить указанное число записей;\n    + `$limit` - ограничить количество записей (не более 1000);\n    + `$webinarTimeMin` - нижняя граница для времени сеанса, на который зарегистрированы подписчики, в формате ISO8601;\n    + `$webinarTimeMax` - верхняя граница для времени сеанса, на который зарегистрированы подписчики, в формате ISO8601;\n    + `$registeredTimeMin` - нижняя граница для времени регистрации подписчика в формате ISO8601;\n    + `$registeredTimeMax` - верхняя граница для времени регистрации подписчика в формате ISO8601;\n    + `$url_marker` - значение маркера из URL, идентификатор партнера.\n-   `getAllWebinarSubscribers(string $pageId, int $skip = 0, int $limit = 1000, string $webinarTimeMin = null, string $webinarTimeMax = null, string $registeredTimeMin = null, string $registeredTimeMax = null, string $url_marker = null) :array`  \n    Возвращает список *всех* подписчиков для заданной страницы регистрации.\n    + `$pageId` - ID страницы регистрации;\n    + `$skip` - пропустить указанное число записей;\n    + `$limit` - количество записей в одном ответе от API (не более 1000);\n    + `$webinarTimeMin` - нижняя граница для времени сеанса, на который зарегистрированы подписчики, в формате ISO8601;\n    + `$webinarTimeMax` - верхняя граница для времени сеанса, на который зарегистрированы подписчики, в формате ISO8601;\n    + `$registeredTimeMin` - нижняя граница для времени регистрации подписчика в формате ISO8601;\n    + `$registeredTimeMax` - верхняя граница для времени регистрации подписчика в формате ISO8601;\n    + `$url_marker` - значение маркера из URL, идентификатор партнера.\n\n\u003ca id=\"%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B-1\"\u003e\u003c/a\u003e\n#### Примеры\n```php\nuse App\\Bizon365\\{Bizon365API, Bizon365APIException};\n\ntry {\n    // Авторизация через токен пользователя\n    $token = 'exampleIBJ4P30oN38H2W4nr1Va4ry4PnH7s4p38S5Xv6B7EoI';\n    $bizon365 = new Bizon365API($token);\n\n    // Получаем список из 100 страниц регистрации и их рассылок\n    $subpages = $bizon365-\u003egetWebinarSubpages($skip = 0, $limit = 100);\n    print_r($subpages);\n\n    // Получаем список комнат\n    $response = $this-\u003ehttp-\u003egetResponse(false);\n    print_r($response['rooms']);\n\n    // Получаем список всех страниц регистрации и их рассылок\n    $subpages = $bizon365-\u003egetAllWebinarSubpages();\n    print_r($subpages);\n\n    // Получаем список всех подписчиков вебинаров на заданной странице регистрации за 31 июля 2020 г.\n    $pageId = '123456:as';\n    $webinarTimeMin = '2020-07-31T00:00:00+03:00';\n    $webinarTimeMax = '2020-07-31T23:59:59+03:00';\n    $subscribers = $bizon365-\u003egetAllWebinarSubscribers($pageId, 0, 1000, $webinarTimeMin, $webinarTimeMax);\n\n    // Выполняем выход\n    $bizon365-\u003elogout();\n\n} catch (Bizon365APIException $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n} catch (Exception $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n}\n```\n\n\u003ca id=\"%D0%92%D1%81%D0%BF%D0%BE%D0%BC%D0%BE%D0%B3%D0%B0%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D1%8B%D0%B5-%D0%BA%D0%BB%D0%B0%D1%81%D1%81%D1%8B\"\u003e\u003c/a\u003e\n## Вспомогательные классы\n\n\u003ca id=\"%D0%9A%D0%BB%D0%B0%D1%81%D1%81-http\"\u003e\u003c/a\u003e\n### Класс `HTTP`\n\nКласс [`\\App\\HTTP\\НТТР`](https://github.com/andrey-tech/http-client-php) обеспечивает:\n\n- формирование POST запросов к API Бизон 365 по протоколу HTTPS;\n- настраиваемый троттлинг запросов к API (по умолчанию отключен);\n- вывод отладочной информации о запросах к API в STDOUT.\n\nПри возникновении ошибок выбрасывается исключение с объектом класса `\\App\\HTTP\\HTTPException`.\n\n\u003ca id=\"%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B-2\"\u003e\u003c/a\u003e\n#### Примеры\n\n```php\nuse App\\Bizon365\\{Bizon365API, Bizon365APIException};\nuse App\\HTTP\\HTTP;\n\ntry {\n    $bizon365 = new Bizon365API();\n\n    // Устанавливаем максимальный уровень вывода отладочных сообщений в STDOUT\n    $bizon365-\u003ehttp-\u003edebugLevel = HTTP::DEBUG_URL |  HTTP::DEBUG_HEADERS | HTTP::DEBUG_CONTENT;\n\n    // Устанавливаем троттлинг запросов на уровне не более 1 запрос в секунду\n    $bizon365-\u003ehttp-\u003ethrottle = 1;\n\n    // Устанавливаем таймаут обмена данными в 30 секунд\n    $bizon365-\u003ehttp-\u003ecurlTimeout = 30;\n\n    // Выполняем авторизацию\n    $bizon365-\u003eauth('ivan@example.com', 'klfi89309gkds');\n\n} catch (Bizon365APIException $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n} catch (Exception $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n}\n```\n\nПримеры отладочных сообщений:\n```\n[1] ===\u003e POST https://online.bizon365.ru/api/v1/auth/login\nPOST /api/v1/auth/login HTTP/1.1\nHost: online.bizon365.ru\nUser-Agent: HTTP-client/2.x.x\nAccept: */*\nContent-type: application/x-www-form-urlencoded\nContent-Length: 47\n\nusername=ivan@example.como\u0026password=klfi89309gkds\n\n[1] \u003c=== RESPONSE 0.6192s (200)\nHTTP/1.1 200 OK\nServer: nginx\nDate: Mon, 15 Jun 2020 12:08:03 GMT\nContent-Type: application/json; charset=utf-8\nContent-Length: 125\nConnection: keep-alive\nX-DNS-Prefetch-Control: off\nX-Frame-Options: SAMEORIGIN\nStrict-Transport-Security: max-age=15552000; includeSubDomains\nX-Download-Options: noopen\nX-Content-Type-Options: nosniff\nX-XSS-Protection: 1; mode=block\nAccess-Control-Allow-Origin: *\nAccess-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, X-Token\nAccess-Control-Allow-Method: HEAD OPTIONS GET POST PUT UPDATE PATCH\nAccess-Control-Max-Age: 86400\nAccess-Control-Allow-Credentials: true\nETag: W/\"7d-8pw4R/X+sbjhsu6o6SkgY7bXiYo\"\nset-cookie: appsid=s%3AmQiE5vQbA-8WS4KCyPS9MHmgKIB1GHA-.XAESPMGN%2FUa4zYLca7UsbIVFjMYjOjw4hjE5N%2Fj2ZBU; Path=/; Expires=Mon, 15 Jun 2020 13:07:48 GMT; HttpOnly\n\n{\"message\":\"Успешная авторизация. Куки отправлены вместе с этим ответом.\"}\n\n```\n\n\u003ca id=\"%D0%9A%D0%BB%D0%B0%D1%81%D1%81-debuglogger\"\u003e\u003c/a\u003e\n### Класс `DebugLogger`\n\nКласс [`\\App\\DebugLogger\\DebugLogger`](https://github.com/andrey-tech/debug-logger-php) обеспечивает логирование запросов и ответов к API Бизон 365 в файл.  \nПри возникновении ошибок выбрасывается исключение класса `\\App\\DebugLogger\\DebugLoggerException`. \n\n\u003ca id=\"%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B-%D0%BA%D0%BB%D0%B0%D1%81%D1%81%D0%B0\"\u003e\u003c/a\u003e\n#### Методы класса\n\n- `static instance(string $logFileName = 'debug.log') :self`  \n    Возвращает единственный объект данного класса **для заданного лог-файла** `$logFileName`.\n    + `$logFileName` - имя лог-файла.\n- `save(mixed $info, object $object = null, string $header = null) :void` Сохраняет подлежащую логированию информацию в файл.\n    + `$info` - строка, массив или объект для логирования;\n    + `$object` - ссылка на объект класса в котором выполняется логирование;\n    + `$header` - строка заголовка для сохраняемой в лог файл информации.\n\n\u003ca id=\"%D0%94%D0%BE%D0%BF%D0%BE%D0%BB%D0%BD%D0%B8%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D1%8B%D0%B5-%D0%BF%D0%B0%D1%80%D0%B0%D0%BC%D0%B5%D1%82%D1%80%D1%8B-1\"\u003e\u003c/a\u003e\n#### Дополнительные параметры\n\nДополнительные параметры устанавливаются через публичные свойства класса `\\App\\DebugLogger\\DebugLogger`:\n\nНестатическое свойство  | По умолчанию  | Описание\n----------------------- | ------------- | --------\n`$isActive`             | false         | Включает или выключает логирование для конкретного файла, задаваемого параметром `$logFileName` метода `instance()`\n\nСтатическое свойство    | По умолчанию  | Описание\n----------------------- | ------------- | --------\n`$logFileDir`           | `temp/`       | Устанавливает каталог, в котором сохраняются лог-файлы\n`mkdirMode`             | 0755          | Устанавливает режим доступа для создаваемых каталогов для хранения лог файлов в виде восьмеричного числа\n`$uniqIdLength`         | 7             | Длина уникального буквенно-цифрового [a-z0-9]+ идентификатора объекта класса `DebugLogger` для сохранения в лог файле,  позволяющего находить записи, созданные одним и тем же процессом\n\n\u003ca id=\"%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B-3\"\u003e\u003c/a\u003e\n#### Примеры\n\n```php\nuse App\\Bizon365\\{Bizon365API, Bizon365APIException};\nuse App\\DebugLogger\\DebugLogger;\n\ntry {\n    $bizon365 = new Bizon365API();\n\n    // Устанавливаем каталог для сохранения лог файлов\n    DebugLogger::$logFileDir = 'logs/';\n\n    // Создаем объект класса логгера\n    $logFileName = 'debug_bizon365api.log';\n    $logger = DebugLogger::instance($logFileName);\n\n    // Включаем логирование\n    $logger-\u003eisActive = true;\n\n    // Устанавливаем логгер\n    $bizon365-\u003esetLogger($logger);\n\n    // Выполняем авторизацию\n    $bizon365-\u003eauth('ivan@example.com', 'klfi89309gkds');\n\n} catch (Bizon365APIException $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n} catch (Exception $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n}\n```\n\nПример результатов логирования:\n```\n*** oun0lym [2020-06-15 12:08:06.732048 +00:00 Δ- s, 0.53/2.00 MiB] ********************\n* Class: App\\Bizon365\\Bizon365API\nЗАПРОС: POST https://online.bizon365.ru/api/v1/auth/login\n{\n    \"username\": \"ivan@example.com\",\n    \"password\": \"klfi89309gkds\"\n}\n\n*** oun0lym [2020-06-15 12:08:07.364074 +00:00 Δ0.632026 s, 0.53/2.00 MiB] ********************\n* Class: App\\Bizon365\\Bizon365API\nОТВЕТ: POST https://online.bizon365.ru/api/v1/auth/login\n{\n    \"message\": \"Успешная авторизация. Куки отправлены вместе с этим ответом.\"\n}\n```\n\n\u003ca id=\"%D0%A4%D0%BE%D1%80%D0%BC%D0%B0%D1%82-%D0%B7%D0%B0%D0%B3%D0%BE%D0%BB%D0%BE%D0%B2%D0%BA%D0%BE%D0%B2-%D0%BB%D0%BE%D0%B3%D0%B0\"\u003e\u003c/a\u003e\n##### Формат заголовков лога\n\n```\n*** oun0lym [2020-06-15 12:08:07.364074 +00:00 Δ0.632026 s, 0.53/2.00 MiB] ********************\n* Class: App\\Bizon365\\Bizon365API\n```\n\n- `oun0lym` - уникальный буквенно-цифровой [a-z0-9]+ идентификатор объекта класса `DebugLogger`, позволяющий находить в лог файле записи, созданные одним и тем же процессом;\n- `2020-06-15 12:08:07.364074 +00:00` - дата и время сохранения информации с точностью до микросекунд;\n- `Δ0.632026 s` - время, прошедшее с момента предыдущего сохранения информации в секундах и микросекундах;\n- `0.53/2.00 MiB` - данные об используемой оперативной памяти в единицах количества информации с [двоичными приставками](https://ru.wikipedia.org/wiki/%D0%94%D0%B2%D0%BE%D0%B8%D1%87%D0%BD%D1%8B%D0%B5_%D0%BF%D1%80%D0%B8%D1%81%D1%82%D0%B0%D0%B2%D0%BA%D0%B8):\n    + `0.53` - максимальный объем памяти, который был выделен PHP-скрипту системой;\n    + `2.00` - реальный объем памяти, выделенный PHP-скрипту системой;\n- `Class: App\\Bizon365\\Bizon365API` - полное имя класса из которого выполнено сохранение в лог файл.\n\n\u003ca id=\"%D0%90%D0%B2%D1%82%D0%BE%D1%80\"\u003e\u003c/a\u003e\n## Автор\n\n© 2019-2021 andrey-tech\n\n\u003ca id=\"%D0%9B%D0%B8%D1%86%D0%B5%D0%BD%D0%B7%D0%B8%D1%8F\"\u003e\u003c/a\u003e\n## Лицензия\n\nДанный код распространяется на условиях лицензии [MIT](./LICENSE).\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fandrey-tech%2Fbizon365-api-php","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fandrey-tech%2Fbizon365-api-php","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fandrey-tech%2Fbizon365-api-php/lists"}