You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
shipin/crmeb/services/AccessTokenServeService.php

175 lines
4.3 KiB

10 months ago
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace crmeb\services;
use crmeb\exceptions\ApiException;
/**
* Class AccessTokenServeService
* @package crmeb\services
*/
class AccessTokenServeService extends HttpService
{
/**
* 配置
* @var string
*/
protected $account;
/**
* @var string
*/
protected $secret;
/**
* @var string
*/
protected $accessToken;
/**
* @var string
*/
protected $cacheTokenPrefix = "_crmeb_plat";
/**
* @var string
*/
protected $apiHost = 'http://sms.crmeb.net/api/';
/**
* 沙盒地址
* @var string
*/
protected $sandBoxApi = 'https://api_v2.crmeb.net/api/';
/**
* 沙盒模式
* @var bool
*/
protected $sandBox = false;
/**
* 登录接口
*/
const USER_LOGIN = "v2/user/login";
/**
* AccessTokenServeService constructor.
* @param string $account
* @param string $secret
*/
public function __construct(string $account, string $secret)
{
$this->account = $account;
$this->secret = $secret;
}
/**
* 获取配置
* @return array
*/
public function getConfig()
{
return [
'access_key' => $this->account,
'secret_key' => $this->secret
];
}
/**
* 获取缓存token
* @return mixed
* @throws \Psr\SimpleCache\InvalidArgumentException
*/
public function getToken()
{
$accessTokenKey = md5($this->account . '_v2_' . $this->secret . $this->cacheTokenPrefix);
$cacheToken = CacheService::get($accessTokenKey);
if (!$cacheToken) {
$getToken = $this->getTokenFromServer();
CacheService::set($accessTokenKey, $getToken['access_token'], $getToken['expires_in'] - 60);
$cacheToken = $getToken['access_token'];
}
$this->accessToken = $cacheToken;
return $cacheToken;
}
/**
* 从服务器获取token
* @return mixed
*/
public function getTokenFromServer()
{
$params = [
'access_key' => $this->account,
'secret_key' => $this->secret,
];
$response = $this->postRequest($this->get(self::USER_LOGIN), $params);
$response = json_decode($response, true);
if (!$response) {
throw new ApiException(410085, ['msg' => '']);
}
if ($response['status'] === 200) {
return $response['data'];
} else {
throw new ApiException(410085, ['msg' => ':' . $response['msg']]);
}
}
/**
* 请求
* @param string $url
* @param array $data
* @param string $method
* @param bool $isHeader
* @return array|mixed
*/
public function httpRequest(string $url, array $data = [], string $method = 'POST', bool $isHeader = true, array $header = [])
{
if ($isHeader) {
$this->getToken();
if (!$this->accessToken) {
throw new ApiException(410086);
}
$header = array_merge($header, ['Authorization:Bearer-' . $this->accessToken]);
}
$res = $this->request($this->get($url), $method, $data, $header);
if (!$res) {
throw new ApiException(410087);
}
$result = json_decode($res, true) ?: false;
if (!isset($result['status']) || $result['status'] != 200) {
throw new ApiException($result['msg']);
}
return $result['data'] ?? [];
}
/**
* @param string $apiUrl
* @return string
*/
public function get(string $apiUrl = '')
{
if ($this->sandBox) {
return $this->sandBoxApi . $apiUrl;
}
return $this->apiHost . $apiUrl;
}
}