vlsv/sber-api-registry-oauth-client 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

vlsv/sber-api-registry-oauth-client

最新稳定版本:v1.1.9

Composer 安装命令:

composer require vlsv/sber-api-registry-oauth-client

包简介

Клиент для работы с токенами Sber API Registry

README 文档

README

phpunit tests

Клиент для работы с токенами Sber API Registry

Получение access_token для последующей работы с доступными API.

Базовые сведения

Описание доработок, которые необходимо выполнить на стороне сервиса вызова API - Настройки сервиса вызова API. Вызов API осуществляется согласно спецификации Oauth 2.0, который предполагает первичное получение токена, разрешающего выполнить непосредственный запрос API (access_token).

ВАЖНО! Новый токен нужно получать для каждого нового запроса к API. Срок жизни токена составляет 60 сек.

Токены реализуются двух видов:

  1. OAUTH-токен - если не требуется доступ к клиентским данным и не требуется согласие клиента на получение его данных.
  2. OIDC-токен - если продукт API предполагает работу с данными клиента, в рамках установленных согласий клиентов.

Требования к переменным окружения

Для получения токена потребуются:

  1. ClientId и ClientSecret для их получения зарегистрировать приложение.
  2. В целях двустороннего TLS соединения выпустить сертификат.

Установка библиотеки

composer require vlsv/sber-api-registry-oauth-client

Получение сертификата

Официальная документация:

Подготовка сертификата

openssl pkcs12 -in {path_to_certificate}/cert.p12 -out {path_to_certificate}/cert.pem -nodes

Получение access_token

Приведенные параметры методов запроса токена - минимально необходимые, фактически их больше (см. исходники).

require_once(__DIR__ . '/vendor/autoload.php');

$config = new \Vlsv\SberApiRegistryOauthClient\ClientConfig(
    clientId: 'client_id',
    clientSecret: 'client_secret',
    certPath: 'cert_path',
    certPassword: 'cert_password',
);

$oAuthClient = new \Vlsv\SberApiRegistryOauthClient\OAuthClient($config);

// OAUTH-токен
try {
    $accessToken = $oAuthClient
        ->getOauthToken(scope: 'https://api.sberbank.ru/qr/order.create')
        ->getAccessToken();
} catch (\Vlsv\SberApiRegistryOauthClient\Exception\ApiException $exception) {
    echo $exception->getMessage();

    if ($exception->getResponseObject()) {
        echo $exception->getResponseObject()->getMoreInformation();
    }
} catch (\Throwable $exception) {
    echo $exception->getMessage();
}

// OIDC-токен
try {
    $accessToken = $oAuthClient->getOidcToken(
       scope: 'https://api.sberbank.ru/qr/order.create',
       code: 'authorization_code',
       redirectUri: 'redirect_uri',
   )->getAccessToken();
} catch (\Vlsv\SberApiRegistryOauthClient\Exception\ApiException $exception) {
    echo $exception->getMessage();

    if ($exception->getResponseObject()) {
        echo $exception->getResponseObject()->getMoreInformation();
    }
} catch (\Throwable $exception) {
    echo $exception->getMessage();
}

Тесты

Все группы.

composer tests

Feature и unit.

composer tests-feature && composer tests-unit

Для интеграционных тестов (библиотеки):

cp phpunit.xml.dist phpunit.xml

Заполнить переменные CLIENT_ID, CLIENT_SECRET и пр. значениями полученными при регистрации согласно официальной документации. При вызове метода получения токена указан scope из SberPay QR/Плати QR.

composer tests-integration

统计信息

  • 总下载量: 123
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 4
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-08-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固