Files
firefly-iii/app/Notifications/User/BillReminder.php

144 lines
4.2 KiB
PHP
Raw Normal View History

2022-09-18 12:36:35 +02:00
<?php
2022-10-16 19:29:53 +02:00
2022-09-18 12:36:35 +02:00
/*
* BillReminder.php
* Copyright (c) 2022 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
2022-10-16 19:29:53 +02:00
declare(strict_types=1);
2022-09-18 12:36:35 +02:00
namespace FireflyIII\Notifications\User;
2022-09-23 06:05:22 +02:00
use FireflyIII\Models\Bill;
2023-08-15 13:52:30 +02:00
use FireflyIII\Support\Notifications\UrlValidator;
2023-07-18 18:15:17 +02:00
use FireflyIII\User;
2022-09-23 06:05:22 +02:00
use Illuminate\Bus\Queueable;
use Illuminate\Notifications\Messages\MailMessage;
2023-07-17 20:15:47 +02:00
use Illuminate\Notifications\Messages\SlackMessage;
2022-09-23 06:05:22 +02:00
use Illuminate\Notifications\Notification;
/**
* Class BillReminder
*/
class BillReminder extends Notification
2022-09-18 12:36:35 +02:00
{
2022-09-23 06:05:22 +02:00
use Queueable;
2023-08-15 13:52:30 +02:00
private Bill $bill;
private int $diff;
2022-12-29 19:42:26 +01:00
private string $field;
2022-09-23 06:05:22 +02:00
/**
* Create a new notification instance.
*/
public function __construct(Bill $bill, string $field, int $diff)
{
2023-08-15 13:52:30 +02:00
$this->bill = $bill;
2022-09-23 06:05:22 +02:00
$this->field = $field;
2023-08-15 13:52:30 +02:00
$this->diff = $diff;
2022-09-23 06:05:22 +02:00
}
/**
2022-12-29 19:42:26 +01:00
* Get the array representation of the notification.
2022-09-23 06:05:22 +02:00
*
2023-06-21 12:34:58 +02:00
* @param mixed $notifiable
2023-07-15 16:02:42 +02:00
*
2022-09-23 06:05:22 +02:00
* @return array
2023-12-20 19:35:52 +01:00
*
2023-11-28 18:57:10 +01:00
* @SuppressWarnings(PHPMD.UnusedFormalParameter)
2022-09-23 06:05:22 +02:00
*/
2022-12-29 19:42:26 +01:00
public function toArray($notifiable)
2022-09-23 06:05:22 +02:00
{
2022-12-29 19:42:26 +01:00
return [
];
2022-09-23 06:05:22 +02:00
}
/**
* Get the mail representation of the notification.
*
2023-06-21 12:34:58 +02:00
* @param mixed $notifiable
2023-07-15 16:02:42 +02:00
*
2022-12-29 19:42:26 +01:00
* @return MailMessage
2023-12-20 19:35:52 +01:00
*
2023-11-28 18:57:10 +01:00
* @SuppressWarnings(PHPMD.UnusedFormalParameter)
2022-09-23 06:05:22 +02:00
*/
public function toMail($notifiable)
{
2022-12-29 19:42:26 +01:00
$subject = (string)trans(sprintf('email.bill_warning_subject_%s', $this->field), ['diff' => $this->diff, 'name' => $this->bill->name]);
2022-09-23 06:05:22 +02:00
if (0 === $this->diff) {
2022-12-29 19:42:26 +01:00
$subject = (string)trans(sprintf('email.bill_warning_subject_now_%s', $this->field), ['diff' => $this->diff, 'name' => $this->bill->name]);
2022-09-23 06:05:22 +02:00
}
2022-10-30 14:24:28 +01:00
return (new MailMessage())
2022-09-23 06:05:22 +02:00
->markdown('emails.bill-warning', ['field' => $this->field, 'diff' => $this->diff, 'bill' => $this->bill])
2023-12-20 19:35:52 +01:00
->subject($subject)
;
2022-09-23 06:05:22 +02:00
}
2022-09-18 12:36:35 +02:00
2022-09-24 12:14:27 +02:00
/**
* Get the Slack representation of the notification.
*
2023-06-21 12:34:58 +02:00
* @param mixed $notifiable
2023-07-15 16:02:42 +02:00
*
2022-09-24 12:14:27 +02:00
* @return SlackMessage
2023-12-20 19:35:52 +01:00
*
2023-11-28 18:57:10 +01:00
* @SuppressWarnings(PHPMD.UnusedFormalParameter)
2022-09-24 12:14:27 +02:00
*/
public function toSlack($notifiable)
{
2022-12-29 19:42:26 +01:00
$message = (string)trans(sprintf('email.bill_warning_subject_%s', $this->field), ['diff' => $this->diff, 'name' => $this->bill->name]);
2022-09-24 12:14:27 +02:00
if (0 === $this->diff) {
2022-12-29 19:42:26 +01:00
$message = (string)trans(sprintf('email.bill_warning_subject_now_%s', $this->field), ['diff' => $this->diff, 'name' => $this->bill->name]);
2022-09-24 12:14:27 +02:00
}
$bill = $this->bill;
2023-08-15 13:52:30 +02:00
$url = route('bills.show', [$bill->id]);
2023-12-20 19:35:52 +01:00
2022-10-30 14:24:28 +01:00
return (new SlackMessage())
2022-09-24 12:14:27 +02:00
->warning()
2023-12-21 05:07:26 +01:00
->attachment(static function ($attachment) use ($bill, $url): void {
2022-12-29 19:42:26 +01:00
$attachment->title((string)trans('firefly.visit_bill', ['name' => $bill->name]), $url);
2022-09-24 12:14:27 +02:00
})
2023-12-20 19:35:52 +01:00
->content($message)
;
2022-09-24 12:14:27 +02:00
}
2022-09-23 06:05:22 +02:00
/**
2022-12-29 19:42:26 +01:00
* Get the notification's delivery channels.
2022-09-23 06:05:22 +02:00
*
2023-06-21 12:34:58 +02:00
* @param mixed $notifiable
2023-07-15 16:02:42 +02:00
*
2022-09-23 06:05:22 +02:00
* @return array
2023-12-20 19:35:52 +01:00
*
2023-11-28 18:57:10 +01:00
* @SuppressWarnings(PHPMD.UnusedFormalParameter)
2022-09-23 06:05:22 +02:00
*/
2022-12-29 19:42:26 +01:00
public function via($notifiable)
2022-09-23 06:05:22 +02:00
{
2023-12-20 19:35:52 +01:00
/** @var null|User $user */
2023-08-15 13:52:30 +02:00
$user = auth()->user();
2023-11-28 04:45:07 +01:00
$slackUrl = null === $user ? '' : app('preferences')->getForUser(auth()->user(), 'slack_webhook_url', '')->data;
if (is_array($slackUrl)) {
$slackUrl = '';
}
2023-11-28 18:57:10 +01:00
if (UrlValidator::isValidWebhookURL((string)$slackUrl)) {
2023-07-17 20:33:26 +02:00
return ['mail', 'slack'];
}
2023-12-20 19:35:52 +01:00
2023-07-17 20:33:26 +02:00
return ['mail'];
2022-09-23 06:05:22 +02:00
}
2022-09-18 12:36:35 +02:00
}