Skip to content

Commit a1ec817

Browse files
committed
initial release
0 parents  commit a1ec817

File tree

3 files changed

+139
-0
lines changed

3 files changed

+139
-0
lines changed

composer.json

Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
{
2+
"name": "sineld/onesignal-mail",
3+
"description": "Package to send emails via Onesignal Mail Provider",
4+
"type": "library",
5+
"keywords": [
6+
"laravel",
7+
"onesignal",
8+
"email",
9+
"onesignal email",
10+
"sineld"
11+
],
12+
"require": {
13+
"guzzlehttp/guzzle": "^7.8",
14+
"laravel/framework": "^9.0|^10.0|^11.0"
15+
},
16+
"minimum-stability": "dev",
17+
"prefer-stable": true,
18+
"license": "MIT",
19+
"autoload": {
20+
"psr-4": {
21+
"Sineld\\OneSignalMail\\": "src/"
22+
}
23+
},
24+
"authors": [
25+
{
26+
"name": "Sinan Eldem",
27+
"email": "sinan@sinaneldem.com.tr"
28+
}
29+
],
30+
"extra": {
31+
"branch-alias": {
32+
"dev-main": "dev"
33+
}
34+
}
35+
}
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
<?php
2+
3+
namespace Sineld\OneSignalMail;
4+
5+
use Illuminate\Mail\MailManager;
6+
use Illuminate\Support\ServiceProvider;
7+
8+
class OneSignalMailServiceProvider extends ServiceProvider
9+
{
10+
/**
11+
* Register services.
12+
*/
13+
public function register(): void
14+
{
15+
$this->app->afterResolving(MailManager::class, function (MailManager $manager) {
16+
$manager->extend('onesignal-mail', function () {
17+
$config = $this->app['config']->get('mail.mailers.onesignal-mail', []);
18+
19+
return new OneSignalTransport(
20+
$config['api_url'],
21+
$config['api_key'],
22+
$config['app_id'],
23+
);
24+
});
25+
});
26+
}
27+
}

src/OneSignalTransport.php

Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
<?php
2+
3+
namespace Sineld\OneSignalMail;
4+
5+
use Exception;
6+
use Illuminate\Support\Facades\Http;
7+
use Illuminate\Support\Str;
8+
use Symfony\Component\Mime\Email;
9+
use Symfony\Component\Mailer\SentMessage;
10+
use Symfony\Component\Mime\MessageConverter;
11+
use Symfony\Component\Mailer\Transport\AbstractTransport;
12+
13+
class OneSignalTransport extends AbstractTransport
14+
{
15+
protected string $apiUrl;
16+
17+
protected string $apiKey;
18+
19+
protected string $appId;
20+
21+
public function __construct(string $apiUrl, string $apiKey, string $appId)
22+
{
23+
parent::__construct();
24+
25+
$this->apiUrl = $apiUrl;
26+
27+
$this->apiKey = $apiKey;
28+
29+
$this->appId = $appId;
30+
}
31+
32+
public function __toString(): string
33+
{
34+
return 'onesignal-mail';
35+
}
36+
37+
/**
38+
* @throws Exception
39+
*/
40+
public function doSend(SentMessage $message): void
41+
{
42+
$email = MessageConverter::toEmail($message->getOriginalMessage());
43+
44+
$response = Http::withHeaders([
45+
'Content-Type' => 'application/json;charset=utf-8',
46+
'Authorization' => 'Basic '.$this->apiKey,
47+
])->post($this->apiUrl, [
48+
'app_id' => $this->appId,
49+
'email_subject' => $email->getSubject(),
50+
'email_body' => $email->getHtmlBody(),
51+
'email_from_name' => $email->getFrom()[0]->getName(),
52+
'email_from_address' => $email->getFrom()[0]->getAddress(),
53+
'email_reply_to_address' => $this->getEmailAddresses($email, 'getReplyTo'),
54+
'email_preheader' => Str::limit($email->getTextBody(), 64),
55+
'include_email_tokens' => [$this->getEmailAddresses($email)],
56+
'include_unsubscribed' => true,
57+
]);
58+
59+
if($response->failed()){
60+
throw new Exception('OneSignal Email failed. Error: '. $response->body());
61+
}
62+
}
63+
64+
protected function getEmailAddresses(Email $email, string $method = 'getTo'): string
65+
{
66+
$data = call_user_func([$email, $method]);
67+
68+
$addresses = [];
69+
if (is_array($data)) {
70+
foreach ($data as $address) {
71+
$addresses[] = $address->getAddress();
72+
}
73+
}
74+
75+
return implode(',', $addresses);
76+
}
77+
}

0 commit comments

Comments
 (0)