|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of the overtrue/easy-sms.
|
|
|
|
*
|
|
|
|
* (c) overtrue <i@overtrue.me>
|
|
|
|
*
|
|
|
|
* This source file is subject to the MIT license that is bundled
|
|
|
|
* with this source code in the file LICENSE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Overtrue\EasySms\Gateways;
|
|
|
|
|
|
|
|
use Overtrue\EasySms\Contracts\MessageInterface;
|
|
|
|
use Overtrue\EasySms\Contracts\PhoneNumberInterface;
|
|
|
|
use Overtrue\EasySms\Exceptions\GatewayErrorException;
|
|
|
|
use Overtrue\EasySms\Support\Config;
|
|
|
|
use Overtrue\EasySms\Traits\HasHttpRequest;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class Tiniyo Gateway.
|
|
|
|
*
|
|
|
|
* @see https://tiniyo.com/sms.html
|
|
|
|
*/
|
|
|
|
class TiniyoGateway extends Gateway
|
|
|
|
{
|
|
|
|
use HasHttpRequest;
|
|
|
|
|
|
|
|
const ENDPOINT_URL = 'https://api.tiniyo.com/v1/Account/%s/Message';
|
|
|
|
|
|
|
|
const SUCCESS_CODE = '000000';
|
|
|
|
|
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
return 'tiniyo';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param \Overtrue\EasySms\Contracts\PhoneNumberInterface $to
|
|
|
|
* @param \Overtrue\EasySms\Contracts\MessageInterface $message
|
|
|
|
* @param \Overtrue\EasySms\Support\Config $config
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*
|
|
|
|
* @throws \Overtrue\EasySms\Exceptions\GatewayErrorException
|
|
|
|
*/
|
|
|
|
public function send(PhoneNumberInterface $to, MessageInterface $message, Config $config)
|
|
|
|
{
|
|
|
|
$accountSid = $config->get('account_sid');
|
|
|
|
$endpoint = $this->buildEndPoint($accountSid);
|
|
|
|
|
|
|
|
$params = [
|
|
|
|
'dst' => $to->getUniversalNumber(),
|
|
|
|
'src' => $config->get('from'),
|
|
|
|
'text' => $message->getContent($this),
|
|
|
|
];
|
|
|
|
|
|
|
|
$result = $this->request('post', $endpoint, [
|
|
|
|
'json' => $params,
|
|
|
|
'headers' => [
|
|
|
|
'Accept' => 'application/json',
|
|
|
|
'Content-Type' => 'application/json;charset=utf-8',
|
|
|
|
'Authorization' => base64_encode($config->get('account_sid').':'.$config->get('token')),
|
|
|
|
],
|
|
|
|
]);
|
|
|
|
|
|
|
|
if (self::SUCCESS_CODE != $result['statusCode']) {
|
|
|
|
throw new GatewayErrorException($result['statusCode'], $result['statusCode'], $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* build endpoint url.
|
|
|
|
*
|
|
|
|
* @param string $accountSid
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
protected function buildEndPoint($accountSid)
|
|
|
|
{
|
|
|
|
return sprintf(self::ENDPOINT_URL, $accountSid);
|
|
|
|
}
|
|
|
|
}
|