* * 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); } }