1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-13 22:54:25 +01:00
invoiceninja/app/Services/PushService.php
2016-07-21 15:35:23 +03:00

157 lines
4.1 KiB
PHP

<?php
namespace App\Services;
use App\Models\Account;
use App\Models\Invoice;
use App\Ninja\Notifications\PushFactory;
/**
* Class PushService
*/
class PushService
{
/**
* @var PushFactory
*/
protected $pushFactory;
/**
* @param PushFactory $pushFactory
*/
public function __construct(PushFactory $pushFactory)
{
$this->pushFactory = $pushFactory;
}
/**
* @param Invoice $invoice
* @param $type
*/
public function sendNotification(Invoice $invoice, $type)
{
if (! IOS_PUSH_CERTIFICATE) {
return;
}
//check user has registered for push notifications
if(!$this->checkDeviceExists($invoice->account))
return;
//Harvest an array of devices that are registered for this notification type
$devices = json_decode($invoice->account->devices, TRUE);
foreach($devices as $device)
{
if(($device["notify_{$type}"] == TRUE) && ($device['device'] == 'ios'))
$this->pushMessage($invoice, $device['token'], $type);
}
}
/**
* pushMessage function
*
* method to dispatch iOS notifications
*
* @param Invoice $invoice
* @param $token
* @param $type
*/
private function pushMessage(Invoice $invoice, $token, $type)
{
$this->pushFactory->message($token, $this->messageType($invoice, $type));
}
/**
* checkDeviceExists function
*
* Returns a boolean if this account has devices registered for PUSH notifications
*
* @param Account $account
*
* @return bool
*/
private function checkDeviceExists(Account $account)
{
$devices = json_decode($account->devices, TRUE);
if(count($devices) >= 1)
return TRUE;
else
return FALSE;
}
/**
* messageType function
*
* method which formats an appropriate message depending on message type
*
* @param Invoice $invoice
* @param $type
*
* @return string
*/
private function messageType(Invoice $invoice, $type)
{
switch($type)
{
case 'sent':
return $this->entitySentMessage($invoice);
break;
case 'paid':
return $this->invoicePaidMessage($invoice);
break;
case 'approved':
return $this->quoteApprovedMessage($invoice);
break;
case 'viewed':
return $this->entityViewedMessage($invoice);
break;
}
}
/**
* @param Invoice $invoice
* @return string
*/
private function entitySentMessage(Invoice $invoice)
{
if($invoice->isType(INVOICE_TYPE_QUOTE))
return trans('texts.notification_quote_sent_subject', ['invoice' => $invoice->invoice_number, 'client' => $invoice->client->name]);
else
return trans('texts.notification_invoice_sent_subject', ['invoice' => $invoice->invoice_number, 'client' => $invoice->client->name]);
}
/**
* @param Invoice $invoice
* @return string
*/
private function invoicePaidMessage(Invoice $invoice)
{
return trans('texts.notification_invoice_paid_subject', ['invoice' => $invoice->invoice_number, 'client' => $invoice->client->name]);
}
/**
* @param Invoice $invoice
* @return string
*/
private function quoteApprovedMessage(Invoice $invoice)
{
return trans('texts.notification_quote_approved_subject', ['invoice' => $invoice->invoice_number, 'client' => $invoice->client->name]);
}
/**
* @param Invoice $invoice
* @return string
*/
private function entityViewedMessage(Invoice $invoice)
{
if($invoice->isType(INVOICE_TYPE_QUOTE))
return trans('texts.notification_quote_viewed_subject', ['invoice' => $invoice->invoice_number, 'client' => $invoice->client->name]);
else
return trans('texts.notification_invoice_viewed_subject', ['invoice' => $invoice->invoice_number, 'client' => $invoice->client->name]);
}
}