1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-11 05:32:39 +01:00
invoiceninja/app/Http/Middleware/StartupCheck.php

123 lines
3.8 KiB
PHP
Raw Normal View History

<?php
2019-05-11 05:32:07 +02:00
/**
* Invoice Ninja (https://invoiceninja.com).
2019-05-11 05:32:07 +02:00
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
2019-05-11 05:32:07 +02:00
*
* @license https://opensource.org/licenses/AAL
*/
namespace App\Http\Middleware;
2020-10-09 04:28:33 +02:00
use App\DataMapper\EmailTemplateDefaults;
use App\Models\Account;
use App\Models\Language;
use App\Utils\CurlUtils;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\App;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Log;
2019-09-26 12:49:52 +02:00
use Illuminate\Support\Facades\Request as Input;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Facades\Session;
/**
* Class StartupCheck.
*/
class StartupCheck
{
/**
* Handle an incoming request.
* @deprecated
* @param Request $request
* @param Closure $next
*
* @return mixed
*/
public function handle(Request $request, Closure $next)
{
// $start = microtime(true);
/* Make sure our cache is built */
$cached_tables = config('ninja.cached_tables');
foreach ($cached_tables as $name => $class) {
if ($request->has('clear_cache') || ! Cache::has($name)) {
// check that the table exists in case the migration is pending
if (! Schema::hasTable((new $class())->getTable())) {
continue;
}
2019-09-11 01:31:55 +02:00
if ($name == 'payment_terms') {
$orderBy = 'num_days';
} elseif ($name == 'fonts') {
$orderBy = 'sort_order';
} elseif (in_array($name, ['currencies', 'industries', 'languages', 'countries', 'banks'])) {
$orderBy = 'name';
} else {
$orderBy = 'id';
}
$tableData = $class::orderBy($orderBy)->get();
if ($tableData->count()) {
Cache::forever($name, $tableData);
}
}
}
2020-10-09 03:59:59 +02:00
/*Build template cache*/
2020-10-09 04:28:33 +02:00
if ($request->has('clear_cache') || ! Cache::has('templates'))
$this->buildTemplates();
2020-10-09 03:59:59 +02:00
$response = $next($request);
return $response;
}
2020-10-09 03:59:59 +02:00
2020-10-09 04:28:33 +02:00
private function buildTemplates($name = 'templates')
2020-10-09 03:59:59 +02:00
{
2020-10-09 04:28:33 +02:00
$data = [
2020-10-09 03:59:59 +02:00
2020-10-09 04:28:33 +02:00
'invoice' => [
2020-10-09 03:59:59 +02:00
'subject' => EmailTemplateDefaults::emailInvoiceSubject(),
2020-10-09 04:28:33 +02:00
'body' => EmailTemplateDefaults::emailInvoiceTemplate(),
],
'quote' => [
'subject' => EmailTemplateDefaults::emailQuoteSubject(),
'body' => EmailTemplateDefaults::emailQuoteTemplate(),
],
'payment' => [
'subject' => EmailTemplateDefaults::emailPaymentSubject(),
'body' => EmailTemplateDefaults::emailPaymentTemplate(),
],
'reminder1' => [
'subject' => EmailTemplateDefaults::emailReminder1Subject(),
'body' => EmailTemplateDefaults::emailReminder1Template(),
],
'reminder2' => [
'subject' => EmailTemplateDefaults::emailReminder2Subject(),
'body' => EmailTemplateDefaults::emailReminder2Template(),
],
'reminder3' => [
'subject' => EmailTemplateDefaults::emailReminder3Subject(),
'body' => EmailTemplateDefaults::emailReminder3Template(),
],
'reminder_endless' => [
'subject' => EmailTemplateDefaults::emailReminderEndlessSubject(),
'body' => EmailTemplateDefaults::emailReminderEndlessTemplate(),
],
'statement' => [
'subject' => EmailTemplateDefaults::emailStatementSubject(),
'body' => EmailTemplateDefaults::emailStatementTemplate(),
],
];
Cache::forever($name, $data);
2020-10-09 03:59:59 +02:00
}
}