Skip to content

Commit

Permalink
Merge pull request #64 from utopia-php/feat-geosms-adapter
Browse files Browse the repository at this point in the history
feat: geosms adapter
  • Loading branch information
abnegate authored Nov 10, 2023
2 parents 2d0f474 + 537aab3 commit 8ba50f7
Show file tree
Hide file tree
Showing 5 changed files with 850 additions and 0 deletions.
110 changes: 110 additions & 0 deletions src/Utopia/Messaging/Adapters/SMS/GEOSMS.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
<?php

namespace Utopia\Messaging\Adapters\SMS;

use Utopia\Messaging\Adapters\SMS as SMSAdapter;
use Utopia\Messaging\Adapters\SMS\GEOSMS\CallingCode;
use Utopia\Messaging\Messages\SMS;

class GEOSMS extends SMSAdapter
{
protected $defaultAdapter;

protected $localAdapters = [];

public function __construct(SMSAdapter $defaultAdapter)
{
$this->defaultAdapter = $defaultAdapter;
}

public function getName(): string
{
return 'GEOSMS';
}

public function getMaxMessagesPerRequest(): int
{
return PHP_INT_MAX;
}

public function setLocal(string $callingCode, SMSAdapter $adapter): self
{
$this->localAdapters[$callingCode] = $adapter;

return $this;
}

protected function filterCallingCodesByAdapter(SMSAdapter $adapter): array
{
$result = [];

foreach ($this->localAdapters as $callingCode => $localAdapter) {
if ($localAdapter === $adapter) {
$result[] = $callingCode;
}
}

return $result;
}

protected function process(SMS $message): string
{
$results = [];
$recipients = $message->getTo();

do {
[$nextRecipients, $nextAdapter] = $this->getNextRecipientsAndAdapter($recipients);

try {
$results[$nextAdapter->getName()] = json_decode($nextAdapter->send(
new SMS(
to: $nextRecipients,
content: $message->getContent(),
from: $message->getFrom(),
attachments: $message->getAttachments()
)
));
} catch (\Exception $e) {
$results[$nextAdapter->getName()] = [
'type' => 'error',
'message' => $e->getMessage(),
];
}

$recipients = \array_diff($recipients, $nextRecipients);
} while (count($recipients) > 0);

return \json_encode($results);
}

protected function getNextRecipientsAndAdapter(array $recipients): array
{
$nextRecipients = [];
$nextAdapter = null;

foreach ($recipients as $recipient) {
$adapter = $this->getAdapterByPhoneNumber($recipient);

if ($nextAdapter === null || $adapter === $nextAdapter) {
$nextAdapter = $adapter;
$nextRecipients[] = $recipient;
}
}

return [$nextRecipients, $nextAdapter];
}

protected function getAdapterByPhoneNumber(?string $phoneNumber): SMSAdapter
{
$callingCode = CallingCode::fromPhoneNumber($phoneNumber);
if ($callingCode === null || empty($callingCode)) {
return $this->defaultAdapter;
}

if (isset($this->localAdapters[$callingCode])) {
return $this->localAdapters[$callingCode];
}

return $this->defaultAdapter;
}
}
Loading

0 comments on commit 8ba50f7

Please sign in to comment.