mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-11 05:47:28 -08:00
adds Mailables for asset checkin and out
This commit is contained in:
parent
16cffe9a9d
commit
9710436d54
|
@ -64,15 +64,9 @@ class CheckoutableListener
|
||||||
Log::info('Sending email, Locale: ' .($event->checkedOutTo->locale ?? 'default'));
|
Log::info('Sending email, Locale: ' .($event->checkedOutTo->locale ?? 'default'));
|
||||||
// Send Webhook notification
|
// Send Webhook notification
|
||||||
if ($this->shouldSendWebhookNotification()) {
|
if ($this->shouldSendWebhookNotification()) {
|
||||||
// Slack doesn't include the URL in its messaging format, so this is needed to hit the endpoint
|
|
||||||
if (Setting::getSettings()->webhook_selected === 'slack' || Setting::getSettings()->webhook_selected === 'general') {
|
|
||||||
Notification::route('slack', Setting::getSettings()->webhook_endpoint)
|
|
||||||
->notify($this->getCheckoutNotification($event, $acceptance));
|
|
||||||
} else {
|
|
||||||
Notification::route(Setting::getSettings()->webhook_selected, Setting::getSettings()->webhook_endpoint)
|
Notification::route(Setting::getSettings()->webhook_selected, Setting::getSettings()->webhook_endpoint)
|
||||||
->notify($this->getCheckoutNotification($event, $acceptance));
|
->notify($this->getCheckoutNotification($event, $acceptance));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
} catch (ClientException $e) {
|
} catch (ClientException $e) {
|
||||||
Log::debug("Exception caught during checkout notification: " . $e->getMessage());
|
Log::debug("Exception caught during checkout notification: " . $e->getMessage());
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
|
@ -111,7 +105,7 @@ class CheckoutableListener
|
||||||
$mailable = (new CheckInAssetMail(
|
$mailable = (new CheckInAssetMail(
|
||||||
$event->checkoutable,
|
$event->checkoutable,
|
||||||
$event->checkedOutTo,
|
$event->checkedOutTo,
|
||||||
$event->checkedOutBy,
|
$event->checkedInBy,
|
||||||
$event->note,
|
$event->note,
|
||||||
));
|
));
|
||||||
|
|
||||||
|
|
102
app/Mail/CheckinAssetMail.php
Normal file
102
app/Mail/CheckinAssetMail.php
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Mail;
|
||||||
|
|
||||||
|
use App\Helpers\Helper;
|
||||||
|
use App\Models\Asset;
|
||||||
|
use App\Models\Setting;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Mail\Mailable;
|
||||||
|
use Illuminate\Mail\Mailables\Address;
|
||||||
|
use Illuminate\Mail\Mailables\Content;
|
||||||
|
use Illuminate\Mail\Mailables\Envelope;
|
||||||
|
use Illuminate\Notifications\Messages\MailMessage;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
|
||||||
|
class CheckinAssetMail extends Mailable
|
||||||
|
{
|
||||||
|
use Queueable, SerializesModels;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new message instance.
|
||||||
|
*/
|
||||||
|
public function __construct(Asset $asset, $checkedOutTo, User $checkedInBy, $note)
|
||||||
|
{
|
||||||
|
$this->target = $checkedOutTo;
|
||||||
|
$this->item = $asset;
|
||||||
|
$this->admin = $checkedInBy;
|
||||||
|
$this->note = $note;
|
||||||
|
|
||||||
|
$this->settings = Setting::getSettings();
|
||||||
|
$this->expected_checkin = '';
|
||||||
|
|
||||||
|
if ($this->item->expected_checkin) {
|
||||||
|
$this->expected_checkin = Helper::getFormattedDateObject($this->item->expected_checkin, 'date',
|
||||||
|
false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the message envelope.
|
||||||
|
*/
|
||||||
|
public function envelope(): Envelope
|
||||||
|
{
|
||||||
|
$from = null;
|
||||||
|
$cc = [];
|
||||||
|
|
||||||
|
if (!empty(Setting::getSettings()->alert_email)) {
|
||||||
|
$from = new Address(Setting::getSettings()->alert_email);
|
||||||
|
}
|
||||||
|
if (!empty(Setting::getSettings()->admin_cc_email)) {
|
||||||
|
$cc[] = new Address(Setting::getSettings()->admin_cc_email);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Envelope(
|
||||||
|
from: $from ?? new Address('default@example.com', 'Default Sender'),
|
||||||
|
cc: $cc,
|
||||||
|
subject: trans('mail.Asset_Checkin_Notification'),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the mail representation of the notification.
|
||||||
|
*
|
||||||
|
* @param mixed $notifiable
|
||||||
|
* @return Content
|
||||||
|
*/
|
||||||
|
public function content(): Content
|
||||||
|
{
|
||||||
|
$this->item->load('assetstatus');
|
||||||
|
$fields = [];
|
||||||
|
|
||||||
|
// Check if the item has custom fields associated with it
|
||||||
|
if (($this->item->model) && ($this->item->model->fieldset)) {
|
||||||
|
$fields = $this->item->model->fieldset->fields;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Content(
|
||||||
|
markdown: 'mail.markdown.checkin-asset',
|
||||||
|
with: [
|
||||||
|
'item' => $this->item,
|
||||||
|
'status' => $this->item->assetstatus?->name,
|
||||||
|
'admin' => $this->admin,
|
||||||
|
'note' => $this->note,
|
||||||
|
'target' => $this->target,
|
||||||
|
'fields' => $fields,
|
||||||
|
'expected_checkin' => $this->expected_checkin,
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the attachments for the message.
|
||||||
|
*
|
||||||
|
* @return array<int, \Illuminate\Mail\Mailables\Attachment>
|
||||||
|
*/
|
||||||
|
public function attachments(): array
|
||||||
|
{
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}
|
150
app/Mail/CheckoutAssetMail.php
Normal file
150
app/Mail/CheckoutAssetMail.php
Normal file
|
@ -0,0 +1,150 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Mail;
|
||||||
|
|
||||||
|
use App\Helpers\Helper;
|
||||||
|
use App\Models\Asset;
|
||||||
|
use App\Models\Setting;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Mail\Mailable;
|
||||||
|
use Illuminate\Mail\Mailables\Address;
|
||||||
|
use Illuminate\Mail\Mailables\Attachment;
|
||||||
|
use Illuminate\Mail\Mailables\Content;
|
||||||
|
use Illuminate\Mail\Mailables\Envelope;
|
||||||
|
use Illuminate\Notifications\Messages\MailMessage;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
|
||||||
|
class CheckoutAssetMail extends Mailable
|
||||||
|
{
|
||||||
|
use Queueable, SerializesModels;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new message instance.
|
||||||
|
*/
|
||||||
|
public function __construct(Asset $asset, $checkedOutTo, User $checkedOutBy, $note, $acceptance)
|
||||||
|
{
|
||||||
|
$this->item = $asset;
|
||||||
|
$this->admin = $checkedOutBy;
|
||||||
|
$this->note = $note;
|
||||||
|
$this->target = $checkedOutTo;
|
||||||
|
$this->acceptance = $acceptance;
|
||||||
|
|
||||||
|
$this->settings = Setting::getSettings();
|
||||||
|
|
||||||
|
$this->last_checkout = '';
|
||||||
|
$this->expected_checkin = '';
|
||||||
|
|
||||||
|
if ($this->item->last_checkout) {
|
||||||
|
$this->last_checkout = Helper::getFormattedDateObject($this->item->last_checkout, 'date',
|
||||||
|
false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->item->expected_checkin) {
|
||||||
|
$this->expected_checkin = Helper::getFormattedDateObject($this->item->expected_checkin, 'date',
|
||||||
|
false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the message envelope.
|
||||||
|
*/
|
||||||
|
public function envelope(): Envelope
|
||||||
|
{
|
||||||
|
$from = null;
|
||||||
|
$cc = [];
|
||||||
|
|
||||||
|
if (!empty(Setting::getSettings()->alert_email)) {
|
||||||
|
$from = new Address(Setting::getSettings()->alert_email);
|
||||||
|
}
|
||||||
|
if (!empty(Setting::getSettings()->admin_cc_email)) {
|
||||||
|
$cc[] = new Address(Setting::getSettings()->admin_cc_email);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Envelope(
|
||||||
|
from: $from ?? new Address('default@example.com', 'Default Sender'),
|
||||||
|
cc: $cc,
|
||||||
|
subject: trans('mail.Asset_Checkout_Notification'),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the mail representation of the notification.
|
||||||
|
*
|
||||||
|
* @param mixed $notifiable
|
||||||
|
* @return Content
|
||||||
|
*/
|
||||||
|
public function content(): Content
|
||||||
|
{
|
||||||
|
$this->item->load('assetstatus');
|
||||||
|
$eula = method_exists($this->item, 'getEula') ? $this->item->getEula() : '';
|
||||||
|
$req_accept = method_exists($this->item, 'requireAcceptance') ? $this->item->requireAcceptance() : 0;
|
||||||
|
$fields = [];
|
||||||
|
|
||||||
|
// Check if the item has custom fields associated with it
|
||||||
|
if (($this->item->model) && ($this->item->model->fieldset)) {
|
||||||
|
$fields = $this->item->model->fieldset->fields;
|
||||||
|
}
|
||||||
|
|
||||||
|
$accept_url = is_null($this->acceptance) ? null : route('account.accept.item', $this->acceptance);
|
||||||
|
|
||||||
|
return new Content(
|
||||||
|
markdown: 'mail.markdown.checkout-asset',
|
||||||
|
with: [
|
||||||
|
'item' => $this->item,
|
||||||
|
'admin' => $this->admin,
|
||||||
|
'status' => $this->item->assetstatus?->name,
|
||||||
|
'note' => $this->note,
|
||||||
|
'target' => $this->target,
|
||||||
|
'fields' => $fields,
|
||||||
|
'eula' => $eula,
|
||||||
|
'req_accept' => $req_accept,
|
||||||
|
'accept_url' => $accept_url,
|
||||||
|
'last_checkout' => $this->last_checkout,
|
||||||
|
'expected_checkin' => $this->expected_checkin,
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// public function build()
|
||||||
|
// {
|
||||||
|
// $this->item->load('assetstatus');
|
||||||
|
// $eula = method_exists($this->item, 'getEula') ? $this->item->getEula() : '';
|
||||||
|
// $req_accept = method_exists($this->item, 'requireAcceptance') ? $this->item->requireAcceptance() : 0;
|
||||||
|
// $fields = [];
|
||||||
|
//
|
||||||
|
// // Check if the item has custom fields associated with it
|
||||||
|
// if (($this->item->model) && ($this->item->model->fieldset)) {
|
||||||
|
// $fields = $this->item->model->fieldset->fields;
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// $accept_url = is_null($this->acceptance) ? null : route('account.accept.item', $this->acceptance);
|
||||||
|
//
|
||||||
|
// return $this
|
||||||
|
// ->subject('Asset Checkout Notification')
|
||||||
|
// ->markdown('notifications.markdown.checkout-asset')
|
||||||
|
// ->with([
|
||||||
|
// 'item' => $this->item,
|
||||||
|
// 'admin' => $this->admin,
|
||||||
|
// 'status' => $this->item->assetstatus?->name,
|
||||||
|
// 'note' => $this->note,
|
||||||
|
// 'target' => $this->target,
|
||||||
|
// 'fields' => $fields,
|
||||||
|
// 'eula' => $eula,
|
||||||
|
// 'req_accept' => $req_accept,
|
||||||
|
// 'accept_url' => $accept_url,
|
||||||
|
// 'last_checkout' => $this->last_checkout,
|
||||||
|
// 'expected_checkin' => $this->expected_checkin,
|
||||||
|
// ]);
|
||||||
|
// }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the attachments for the message.
|
||||||
|
*
|
||||||
|
* @return array<int, Attachment>
|
||||||
|
*/
|
||||||
|
public function attachments(): array
|
||||||
|
{
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}
|
|
@ -63,7 +63,7 @@ class CheckinAssetNotification extends Notification
|
||||||
Log::debug('use webhook');
|
Log::debug('use webhook');
|
||||||
$notifyBy[] = 'slack';
|
$notifyBy[] = 'slack';
|
||||||
}
|
}
|
||||||
dd($notifyBy);
|
|
||||||
// /**
|
// /**
|
||||||
// * Only send checkin notifications to users if the category
|
// * Only send checkin notifications to users if the category
|
||||||
// * has the corresponding checkbox checked.
|
// * has the corresponding checkbox checked.
|
||||||
|
@ -141,35 +141,5 @@ dd($notifyBy);
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the mail representation of the notification.
|
|
||||||
*
|
|
||||||
* @return \Illuminate\Notifications\Messages\MailMessage
|
|
||||||
*/
|
|
||||||
public function toMail()
|
|
||||||
{
|
|
||||||
$fields = [];
|
|
||||||
|
|
||||||
// Check if the item has custom fields associated with it
|
|
||||||
if (($this->item->model) && ($this->item->model->fieldset)) {
|
|
||||||
$fields = $this->item->model->fieldset->fields;
|
|
||||||
}
|
|
||||||
|
|
||||||
$message = (new MailMessage)->markdown('notifications.markdown.checkin-asset',
|
|
||||||
[
|
|
||||||
'item' => $this->item,
|
|
||||||
'status' => $this->item->assetstatus?->name,
|
|
||||||
'admin' => $this->admin,
|
|
||||||
'note' => $this->note,
|
|
||||||
'target' => $this->target,
|
|
||||||
'fields' => $fields,
|
|
||||||
'expected_checkin' => $this->expected_checkin,
|
|
||||||
])
|
|
||||||
->subject(trans('mail.Asset_Checkin_Notification'));
|
|
||||||
|
|
||||||
return $message;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ Route::group(['middleware' => 'auth'], function () {
|
||||||
$fields = $item->model->fieldset->fields;
|
$fields = $item->model->fieldset->fields;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new \App\Mail\CheckoutAssetMail(
|
return new \App\Mail\CheckinAssetMail(
|
||||||
$item,
|
$item,
|
||||||
$admin,
|
$admin,
|
||||||
$target,
|
$target,
|
||||||
|
|
Loading…
Reference in a new issue