mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-10-24 15:19:19 -04:00
Working on email history for PostMark
This commit is contained in:
parent
6f23fc3133
commit
e1e99cbd9e
@ -38,15 +38,15 @@ class ProcessPostmarkWebhook implements ShouldQueue
|
|||||||
|
|
||||||
public $invitation;
|
public $invitation;
|
||||||
|
|
||||||
private array $default_response = [
|
private $entity;
|
||||||
'subject' => 'Message not found.',
|
|
||||||
'status' => '',
|
private array $default_response = [
|
||||||
'recipient' => '',
|
'recipients' => '',
|
||||||
'type' => '',
|
'subject' => 'Message not found.',
|
||||||
'delivery_message' => '',
|
'entity' => '',
|
||||||
'server' => '',
|
'entity_id' => '',
|
||||||
'server_ip' => '',
|
'events' => [],
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new job instance.
|
* Create a new job instance.
|
||||||
@ -275,14 +275,19 @@ class ProcessPostmarkWebhook implements ShouldQueue
|
|||||||
$invitation = false;
|
$invitation = false;
|
||||||
|
|
||||||
if ($invitation = InvoiceInvitation::where('message_id', $message_id)->first()) {
|
if ($invitation = InvoiceInvitation::where('message_id', $message_id)->first()) {
|
||||||
|
$this->entity = 'invoice';
|
||||||
return $invitation;
|
return $invitation;
|
||||||
} elseif ($invitation = QuoteInvitation::where('message_id', $message_id)->first()) {
|
} elseif ($invitation = QuoteInvitation::where('message_id', $message_id)->first()) {
|
||||||
|
$this->entity = 'quote';
|
||||||
return $invitation;
|
return $invitation;
|
||||||
} elseif ($invitation = RecurringInvoiceInvitation::where('message_id', $message_id)->first()) {
|
} elseif ($invitation = RecurringInvoiceInvitation::where('message_id', $message_id)->first()) {
|
||||||
|
$this->entity = 'recurring_invoice';
|
||||||
return $invitation;
|
return $invitation;
|
||||||
} elseif ($invitation = CreditInvitation::where('message_id', $message_id)->first()) {
|
} elseif ($invitation = CreditInvitation::where('message_id', $message_id)->first()) {
|
||||||
|
$this->entity = 'credit';
|
||||||
return $invitation;
|
return $invitation;
|
||||||
} elseif ($invitation = PurchaseOrderInvitation::where('message_id', $message_id)->first()) {
|
} elseif ($invitation = PurchaseOrderInvitation::where('message_id', $message_id)->first()) {
|
||||||
|
$this->entity = 'purchase_order';
|
||||||
return $invitation;
|
return $invitation;
|
||||||
} else {
|
} else {
|
||||||
return $invitation;
|
return $invitation;
|
||||||
@ -297,17 +302,31 @@ class ProcessPostmarkWebhook implements ShouldQueue
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
$postmark = new PostmarkClient(config('services.postmark.secret'));
|
$postmark = new PostmarkClient(config('services.postmark.token'));
|
||||||
$messageDetail = $postmark->getOutboundMessageDetails($this->request['MessageID']);
|
$messageDetail = $postmark->getOutboundMessageDetails($this->request['MessageID']);
|
||||||
|
|
||||||
|
$recipients = collect($messageDetail['recipients'])->flatten()->implode(',');
|
||||||
|
$subject = $messageDetail->subject ?? '';
|
||||||
|
|
||||||
|
$events = collect($messageDetail->messageevents)->map(function ($event) {
|
||||||
|
|
||||||
|
return [
|
||||||
|
'recipient' => $event->Recipient ?? '',
|
||||||
|
'status' => $event->Type ?? '',
|
||||||
|
'delivery_message' => $event->Details->DeliveryMessage ?? $event->Details->Summary ?? '',
|
||||||
|
'server' => $event->Details->DestinationServer ?? '',
|
||||||
|
'server_ip' => $event->Details->DestinationIP ?? '',
|
||||||
|
'date' => \Carbon\Carbon::parse($event->ReceivedAt)->format('Y-m-d H:m:s') ?? '',
|
||||||
|
];
|
||||||
|
|
||||||
|
})->toArray();
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'subject' => $messageDetail->subject ?? '',
|
'recipients' => $recipients,
|
||||||
'status' => $messageDetail->status ?? '',
|
'subject' => $subject,
|
||||||
'recipient' => $messageDetail->messageevents[0]['Recipient'] ?? '',
|
'entity' => $this->entity ?? '',
|
||||||
'type' => $messageDetail->messageevents[0]->Type ?? '',
|
'entity_id' => $this->invitation->{$this->entity}->hashed_id ?? '',
|
||||||
'subject' => $messageDetail->messageevents[0]->Details->DeliveryMessage ?? '',
|
'events' => $events,
|
||||||
'server' => $messageDetail->messageevents[0]->Details->DestinationServer ?? '',
|
|
||||||
'server_ip' => $messageDetail->messageevents[0]->Details->DestinationIP ?? '',
|
|
||||||
];
|
];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@ use App\Models\SystemLog;
|
|||||||
use Postmark\PostmarkClient;
|
use Postmark\PostmarkClient;
|
||||||
use App\Services\AbstractService;
|
use App\Services\AbstractService;
|
||||||
|
|
||||||
|
/** @deprecated */
|
||||||
class EmailHistory extends AbstractService
|
class EmailHistory extends AbstractService
|
||||||
{
|
{
|
||||||
private string $postmark_token;
|
private string $postmark_token;
|
||||||
@ -27,7 +28,7 @@ class EmailHistory extends AbstractService
|
|||||||
'status' => '',
|
'status' => '',
|
||||||
'recipient' => '',
|
'recipient' => '',
|
||||||
'type' => '',
|
'type' => '',
|
||||||
'subject' => '',
|
'delivery_message' => '',
|
||||||
'server' => '',
|
'server' => '',
|
||||||
'server_ip' => '',
|
'server_ip' => '',
|
||||||
];
|
];
|
||||||
|
Loading…
x
Reference in New Issue
Block a user