Laravel 11 (#84)

* Convert string references to `::class`

PHP 5.5.9 adds the new static `class` property which provides the fully qualified class name. This is preferred over using strings for class names since the `class` property references are checked by PHP.

* Use Faker methods

Accessing Faker properties was deprecated in Faker 1.14.

* Convert route options to fluent methods

Laravel 8 adopts the tuple syntax for controller actions. Since the old options array is incompatible with this syntax, Shift converted them to use modern, fluent methods.

* Adopt class based routes

* Remove default `app` files

* Shift core files

* Streamline config files

* Set new `ENV` variables

* Default new `bootstrap/app.php`

* Re-register HTTP middleware

* Consolidate service providers

* Re-register service providers

* Re-register routes

* Re-register scheduled commands

* Bump Composer dependencies

* Use `<env>` tags for configuration

`<env>` tags have a lower precedence than system environment variables making it easier to overwrite PHPUnit configuration values in additional environments, such a CI.

Review this blog post for more details on configuration precedence when testing Laravel: https://jasonmccreary.me/articles/laravel-testing-configuration-precedence/

* Adopt anonymous migrations

* Rename `password_resets` table

* Convert `$casts` property to method

* Adopt Laravel type hints

* Mark base controller as `abstract`

* Remove `CreatesApplication` testing trait

* Shift cleanup

* Fix shift first issues

* Updating Rules for laravel 11, sanctum config and pint

* Fix Carbon issue on dashboard

* Temporary fix for tests while migration is issue fixed on laravel side

* Carbon needs numerical values, not strings

* Minimum php version

* Fix domain installation step not fetching the correct company_id

* Fix Role Policy wasn't properly registered

---------
This commit is contained in:
mchev
2024-06-05 11:33:52 +02:00
committed by GitHub
parent 72311db1bd
commit 3259173066
656 changed files with 4964 additions and 7944 deletions

View File

@@ -1,20 +1,21 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Auth;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class AdminMiddleware
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param null $guard
* @return mixed
*/
public function handle($request, Closure $next, $guard = null)
public function handle(Request $request, Closure $next, $guard = null): Response
{
if (Auth::guard($guard)->guest() || ! Auth::user()->isSuperAdminOrAdmin()) {
if ($request->ajax() || $request->wantsJson()) {

View File

@@ -1,6 +1,6 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Illuminate\Auth\Middleware\Authenticate as Middleware;

View File

@@ -1,10 +1,11 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Schema;
use Symfony\Component\HttpFoundation\Response;
class CompanyMiddleware
{
@@ -13,7 +14,7 @@ class CompanyMiddleware
*
* @return mixed
*/
public function handle(Request $request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
if (Schema::hasTable('user_company')) {
$user = $request->user();

View File

@@ -1,20 +1,21 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use App\Models\FileDisk;
use App\Space\InstallUtils;
use Closure;
use InvoiceShelf\Models\FileDisk;
use InvoiceShelf\Space\InstallUtils;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class ConfigMiddleware
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @return mixed
*/
public function handle($request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
if (InstallUtils::isDbCreated()) {
if ($request->has('file_disk_id')) {

View File

@@ -1,9 +1,10 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class CronJobMiddleware
{
@@ -12,7 +13,7 @@ class CronJobMiddleware
*
* @return mixed
*/
public function handle(Request $request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
if ($request->header('x-authorization-token') && $request->header('x-authorization-token') == config('services.cron_job.auth_token')) {
return $next($request);

View File

@@ -1,10 +1,11 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Symfony\Component\HttpFoundation\Response;
class CustomerPortalMiddleware
{
@@ -14,7 +15,7 @@ class CustomerPortalMiddleware
* @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next
* @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse
*/
public function handle(Request $request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
$user = Auth::guard('customer')->user();

View File

@@ -1,6 +1,6 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Illuminate\Cookie\Middleware\EncryptCookies as Middleware;

View File

@@ -1,20 +1,21 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use App\Models\Setting;
use App\Space\InstallUtils;
use Closure;
use InvoiceShelf\Models\Setting;
use InvoiceShelf\Space\InstallUtils;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class InstallationMiddleware
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @return mixed
*/
public function handle($request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
if (! InstallUtils::isDbCreated() || Setting::getSetting('profile_complete') !== 'COMPLETED') {
return redirect('/installation');

View File

@@ -1,10 +1,11 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Symfony\Component\HttpFoundation\Response;
class PdfMiddleware
{
@@ -14,7 +15,7 @@ class PdfMiddleware
* @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next
* @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse
*/
public function handle(Request $request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
if (Auth::guard('web')->check() || Auth::guard('sanctum')->check() || Auth::guard('customer')->check()) {
return $next($request);

View File

@@ -1,10 +1,10 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use App\Providers\RouteServiceProvider;
use Closure;
use Illuminate\Support\Facades\Auth;
use InvoiceShelf\Providers\RouteServiceProvider;
class RedirectIfAuthenticated
{

View File

@@ -1,20 +1,21 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use App\Models\Setting;
use App\Space\InstallUtils;
use Closure;
use InvoiceShelf\Models\Setting;
use InvoiceShelf\Space\InstallUtils;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class RedirectIfInstalled
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @return mixed
*/
public function handle($request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
if (InstallUtils::dbMarkerExists()) {
if (Setting::getSetting('profile_complete') === 'COMPLETED') {

View File

@@ -1,10 +1,11 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Symfony\Component\HttpFoundation\Response;
class RedirectIfUnauthorized
{
@@ -13,7 +14,7 @@ class RedirectIfUnauthorized
*
* @return mixed
*/
public function handle(Request $request, Closure $next, $guard = null)
public function handle(Request $request, Closure $next, $guard = null): Response
{
if (Auth::guard($guard)->check()) {
return $next($request);

View File

@@ -1,9 +1,11 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Silber\Bouncer\Bouncer;
use Symfony\Component\HttpFoundation\Response;
class ScopeBouncer
{
@@ -25,10 +27,9 @@ class ScopeBouncer
/**
* Set the proper Bouncer scope for the incoming request.
*
* @param \Illuminate\Http\Request $request
* @return mixed
*/
public function handle($request, Closure $next)
public function handle(Request $request, Closure $next): Response
{
$user = $request->user();
$tenantId = $request->header('company')

View File

@@ -1,6 +1,6 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\TrimStrings as Middleware;

View File

@@ -1,6 +1,6 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Illuminate\Http\Middleware\TrustProxies as Middleware;
use Illuminate\Http\Request;

View File

@@ -1,6 +1,6 @@
<?php
namespace InvoiceShelf\Http\Middleware;
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as Middleware;