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.
yanzong/app/common/library/sms/Driver.php

150 lines
5.0 KiB

1 year ago
<?php
// +----------------------------------------------------------------------
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
// +----------------------------------------------------------------------
// | Author: 萤火科技 <admin@yiovo.com>
// +----------------------------------------------------------------------
declare (strict_types=1);
namespace app\common\library\sms;
use app\common\library\helper;
use cores\traits\ErrorTrait;
use cores\exception\BaseException;
use Overtrue\EasySms\EasySms;
use Overtrue\EasySms\Exceptions\InvalidArgumentException;
use Overtrue\EasySms\Exceptions\NoGatewayAvailableException;
/**
* 短信通知模块驱动
* Class Driver
* @package app\common\library\sms
*/
class Driver
{
use ErrorTrait;
// 后台短信配置信息
private $smsConfig;
// 当前短信平台 (后台设置)
private $gateway;
/**
* 构造方法
* Driver constructor.
* @param array $smsConfig
*/
public function __construct(array $smsConfig)
{
// 配置信息
$this->smsConfig = $smsConfig;
// 当前短信平台
$this->gateway = $this->smsConfig['default'];
}
/**
* 发送短信通知
* @param string $acceptPhone 接收的手机号
* @param string $templateCode 短信模板ID
* @param array $templateParams 短信模板参数
* @return bool
* @throws BaseException
* @throws InvalidArgumentException
*/
public function sendSms(string $acceptPhone, string $templateCode, array $templateParams): bool
{
// 实例化EasySms
$easySmsConfig = Config::getEasySmsConfig($this->smsConfig);
$easySms = new EasySms($easySmsConfig);
try {
// 执行发送短信
$result = $easySms->send($acceptPhone, [
'template' => $templateCode,
'data' => $this->getSmsTemplateData($templateParams),
]);
// 短信发送成功的错误处理
$sendStatus = $this->resultHandle($result);
} catch (NoGatewayAvailableException $e) {
// 短信发送异常的错误处理
$sendStatus = false;
$this->exceptionHandle($e);
}
// 记录日志
helper::logInfo('发送短信', [
'gateway' => $this->smsConfig['default'],
'acceptPhone' => $acceptPhone,
'templateCode' => $templateCode,
'templateParams' => $templateParams,
'sendStatus' => $sendStatus ? 'true' : 'false',
'sendErrMsg' => $this->getError(),
]);
// 存在异常时抛错
$sendStatus === false && throwError($this->getError());
return $sendStatus;
}
/**
* 短信发送成功的错误处理
* @param array $result
* @return bool
*/
private function resultHandle(array $result): bool
{
// 腾讯云短信错误: 模板ID不正确
if ($this->gateway === 'qcloud') {
$response = $result[$this->gateway]['result']['Response']['SendStatusSet'];
if (isset($response[0]) && isset($response[0]['Code']) && $response[0]['Code'] !== 'Ok') {
$this->error = '请检查后台短信平台参数和模板ID是否正确';
return false;
}
}
return true;
}
/**
* 短信发送异常的错误处理
* @param NoGatewayAvailableException $e
*/
private function exceptionHandle(NoGatewayAvailableException $e)
{
// 短信发送失败
$err = $e->getLastException();
if ($err instanceof \GuzzleHttp\Exception\ClientException) {
$body = (string)$err->getResponse()->getBody();
$result = helper::jsonDecode($body);
if (isset($result['Message'])) {
// $errMsg = $result['Message'];
$this->error = '请检查后台短信平台的参数设置';
return;
}
if (isset($result['message'])) {
$this->error = $result['message'];
return;
}
}
// if ($err instanceof \Overtrue\EasySms\Exceptions\GatewayErrorException) {
// $this->error = $err->getMessage();
// return;
// }
$this->error = $err->getMessage();
}
/**
* 生成短信模板数据
* @param array $templateParams
* @return array
*/
private function getSmsTemplateData(array $templateParams): array
{
if ($this->gateway === 'qcloud') {
$templateParams = array_values($templateParams);
}
return $templateParams;
}
}