-
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathSmsapiTransport.php
127 lines (105 loc) · 3.79 KB
/
SmsapiTransport.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <[email protected]>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Notifier\Bridge\Smsapi;
use Symfony\Component\Notifier\Exception\TransportException;
use Symfony\Component\Notifier\Exception\UnsupportedMessageTypeException;
use Symfony\Component\Notifier\Message\MessageInterface;
use Symfony\Component\Notifier\Message\SentMessage;
use Symfony\Component\Notifier\Message\SmsMessage;
use Symfony\Component\Notifier\Transport\AbstractTransport;
use Symfony\Contracts\EventDispatcher\EventDispatcherInterface;
use Symfony\Contracts\HttpClient\Exception\DecodingExceptionInterface;
use Symfony\Contracts\HttpClient\Exception\TransportExceptionInterface;
use Symfony\Contracts\HttpClient\HttpClientInterface;
/**
* @author Marcin Szepczynski <[email protected]>
*/
final class SmsapiTransport extends AbstractTransport
{
protected const HOST = 'api.smsapi.pl';
private bool $fast = false;
private bool $test = false;
public function __construct(
#[\SensitiveParameter] private string $authToken,
private string $from = '',
?HttpClientInterface $client = null,
?EventDispatcherInterface $dispatcher = null,
) {
parent::__construct($client, $dispatcher);
}
/**
* @return $this
*/
public function setFast(bool $fast): static
{
$this->fast = $fast;
return $this;
}
/**
* @return $this
*/
public function setTest(bool $test): static
{
$this->test = $test;
return $this;
}
public function __toString(): string
{
$query = array_filter([
'from' => $this->from,
'fast' => (int) $this->fast,
'test' => (int) $this->test,
]);
return \sprintf('smsapi://%s%s', $this->getEndpoint(), $query ? '?'.http_build_query($query, '', '&') : '');
}
public function supports(MessageInterface $message): bool
{
return $message instanceof SmsMessage;
}
protected function doSend(MessageInterface $message): SentMessage
{
if (!$message instanceof SmsMessage) {
throw new UnsupportedMessageTypeException(__CLASS__, SmsMessage::class, $message);
}
// default request body
$body = [
'to' => $message->getPhone(),
'message' => $message->getSubject(),
'fast' => $this->fast,
'format' => 'json',
'encoding' => 'utf-8',
'test' => $this->test,
];
if ('' !== $from = $message->getFrom() ?: $this->from) {
$body['from'] = $from;
}
$endpoint = \sprintf('https://%s/sms.do', $this->getEndpoint());
$response = $this->client->request('POST', $endpoint, [
'auth_bearer' => $this->authToken,
'body' => $body,
]);
try {
$statusCode = $response->getStatusCode();
} catch (TransportExceptionInterface $e) {
throw new TransportException('Could not reach the remote Smsapi server.', $response, 0, $e);
}
try {
$content = $response->toArray(false);
} catch (DecodingExceptionInterface $e) {
throw new TransportException('Could not decode body to an array.', $response, 0, $e);
}
if (isset($content['error']) || 200 !== $statusCode) {
throw new TransportException(\sprintf('Unable to send the SMS: "%s".', $content['message'] ?? 'unknown error'), $response);
}
$sentMessage = new SentMessage($message, (string) $this);
$sentMessage->setMessageId($content['list'][0]['id'] ?? '');
return $sentMessage;
}
}