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.
175 lines
4.3 KiB
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;
|
||
|
}
|
||
|
}
|