beta/bx.jwt

JWT tokens for Bitrix app

Installs: 1 441

Dependents: 1

Suggesters: 0

Security: 0

Stars: 5

Watchers: 4

Forks: 4

Open Issues: 0

Type:bitrix-module

1.3.2 2022-11-05 21:13 UTC

This package is auto-updated.

Last update: 2024-05-06 00:18:41 UTC


README

Установка

composer require beta/bx.jwt

Использование

В админке прописываем ключ для подписи (по-умолчанию уже есть), заголовок для передачи токена и время жизни токена - /bitrix/admin/settings.php?lang=ru&mid=bx.jwt&mid_menu=1

Инициализируем сервис JWT:

use Bitrix\Main\Config\Option;
use Bx\JWT\UserTokenService;
use Bx\JWT\Strategy\HS256TokenStrategy;
use Bx\JWT\UserDataPacker;
use Bx\Model\Services\UserService;

$ttl = (int)Option::get('bx.jwt', 'JWT_TTL', 86400);   // время жизни токена
$jwtHeader = (string)Option::get('bx.jwt', 'JWT_HTTP_HEADER', 'X-API-Key');
$userService = new UserService();
$userTokenService = new UserTokenService(
    new HS256TokenStrategy(),               // стратегия для подписи токена
    new UserDataPacker($ttl, $userService), // упаковщик данных (здесь определяется какие данные будут записаны в токене)
    $userService                            // сервис для работы с пользователями
);

Генерируем токен пользователя:

use Bx\JWT\Interfaces\UserTokenServiceInterface;

/**
* @var UserTokenServiceInterface $userTokenService
*/
$tokenContext = $userTokenService->createToken(1);  // генерируем токен для пользователя с идентификатором 1
(string)$tokenContext; // текстовое представление токена

Читаем полученный токен пользователя:

use Bx\JWT\Interfaces\UserTokenServiceInterface;

/**
* @var UserTokenServiceInterface $userTokenService
*/

$tokenStr = '....'; // JWT токен
$tokenContext = $userTokenService->readToken($tokenStr);
$tokenContext->getUid();    // уникальный идентификатор использованный упаковщиком при генерации токена
$tokenContext->getData();   // запакованные в JWT токен данные в виде stdClass

$userContext = $userTokenService->getUserContext($tokenStr);
$userContext->getUserId();          // идентификатор пользователя
$user = $userContext->getUser();    // модель пользователя
$user->getId();
$user->getName();
$user->getLastName();
$user->getSecondName();
$user->getEmail();
$user->getPhone();