mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-08 20:22:42 +01:00
171 lines
3.9 KiB
PHP
171 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace App\Services;
|
|
|
|
use Illuminate\Http\Request;
|
|
use App\Ninja\Notifications\PushFactory;
|
|
/**
|
|
* Class PushService
|
|
* @package App\Ninja\Notifications
|
|
*/
|
|
|
|
|
|
/**
|
|
* $account->devices Definition
|
|
*
|
|
* @param string token (push notification device token)
|
|
* @param string email (user email address - required for use as key)
|
|
* @param string device (ios, gcm etc etc)
|
|
* @param bool notify_sent
|
|
* @param bool notify_paid
|
|
* @param bool notify_approved
|
|
* @param bool notify_viewed
|
|
*/
|
|
|
|
class PushService
|
|
{
|
|
protected $pushFactory;
|
|
|
|
/**
|
|
* @param PushFactory $pushFactory
|
|
*/
|
|
public function __construct(PushFactory $pushFactory)
|
|
{
|
|
$this->pushFactory = $pushFactory;
|
|
}
|
|
|
|
/**
|
|
* @param $invoice - Invoice object
|
|
* @param $type - Type of notification, ie. Quote APPROVED, Invoice PAID, Invoice/Quote SENT, Invoice/Quote VIEWED
|
|
*/
|
|
|
|
public function sendNotification($invoice, $type)
|
|
{
|
|
//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'], $device["notify_{$type}"]);
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* pushMessage function
|
|
*
|
|
* method to dispatch iOS notifications
|
|
*
|
|
* @param $invoice
|
|
* @param $token
|
|
* @param $type
|
|
*/
|
|
private function pushMessage($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
|
|
* @return bool
|
|
*/
|
|
private function checkDeviceExists($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
|
|
* @param $type
|
|
* @return string
|
|
*/
|
|
private function messageType($invoice, $type)
|
|
{
|
|
switch($type)
|
|
{
|
|
case 'notify_sent':
|
|
return $this->entitySentMessage($invoice);
|
|
break;
|
|
|
|
case 'notify_paid':
|
|
return $this->invoicePaidMessage($invoice);
|
|
break;
|
|
|
|
case 'notify_approved':
|
|
return $this->quoteApprovedMessage($invoice);
|
|
break;
|
|
|
|
case 'notify_viewed':
|
|
return $this->entityViewedMessage($invoice);
|
|
break;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param $invoice
|
|
* @return string
|
|
*/
|
|
private function entitySentMessage($invoice)
|
|
{
|
|
if($invoice->is_quote)
|
|
return 'Quote #{$invoice->invoice_number} sent!';
|
|
else
|
|
return 'Invoice #{$invoice->invoice_number} sent!';
|
|
|
|
}
|
|
|
|
/**
|
|
* @param $invoice
|
|
* @return string
|
|
*/
|
|
private function invoicePaidMessage($invoice)
|
|
{
|
|
return 'Invoice #{$invoice->invoice_number} paid!';
|
|
}
|
|
|
|
/**
|
|
* @param $invoice
|
|
* @return string
|
|
*/
|
|
private function quoteApprovedMessage($invoice)
|
|
{
|
|
return 'Quote #{$invoice->invoice_number} approved!';
|
|
}
|
|
|
|
/**
|
|
* @param $invoice
|
|
* @return string
|
|
*/
|
|
private function entityViewedMessage($invoice)
|
|
{
|
|
if($invoice->is_quote)
|
|
return 'Quote #{$invoice->invoice_number} viewed!';
|
|
else
|
|
return 'Invoice #{$invoice->invoice_number} viewed!';
|
|
|
|
}
|
|
|
|
|
|
|
|
} |