Files
InvoiceShelf/bootstrap/app.php
2026-03-21 18:53:33 +01:00

99 lines
3.6 KiB
PHP

<?php
use App\Http\Middleware\Authenticate;
use App\Http\Middleware\CompanyMiddleware;
use App\Http\Middleware\ConfigMiddleware;
use App\Http\Middleware\CronJobMiddleware;
use App\Http\Middleware\CustomerGuest;
use App\Http\Middleware\CustomerPortalMiddleware;
use App\Http\Middleware\CustomerRedirectIfAuthenticated;
use App\Http\Middleware\EncryptCookies;
use App\Http\Middleware\InstallationMiddleware;
use App\Http\Middleware\PdfMiddleware;
use App\Http\Middleware\PreventRequestForgery;
use App\Http\Middleware\RedirectIfAuthenticated;
use App\Http\Middleware\RedirectIfInstalled;
use App\Http\Middleware\RedirectIfUnauthorized;
use App\Http\Middleware\ScopeBouncer;
use App\Http\Middleware\TrimStrings;
use App\Http\Middleware\TrustProxies;
use App\Providers\AppServiceProvider;
use Illuminate\Auth\Middleware\Authorize;
use Illuminate\Foundation\Application;
use Illuminate\Foundation\Configuration\Exceptions;
use Illuminate\Foundation\Configuration\Middleware;
use Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode;
use Illuminate\Routing\Middleware\SubstituteBindings;
use Illuminate\Session\Middleware\AuthenticateSession;
use Illuminate\Session\Middleware\StartSession;
use Illuminate\View\Middleware\ShareErrorsFromSession;
use Lavary\Menu\ServiceProvider;
return Application::configure(basePath: dirname(__DIR__))
->withProviders([
ServiceProvider::class,
])
->withRouting(
web: __DIR__.'/../routes/web.php',
api: __DIR__.'/../routes/api.php',
commands: __DIR__.'/../routes/console.php',
channels: __DIR__.'/../routes/channels.php',
health: '/up',
)
->withMiddleware(function (Middleware $middleware) {
$middleware->redirectGuestsTo(fn () => route('login'));
$middleware->redirectUsersTo(AppServiceProvider::HOME);
$middleware->preventRequestForgery(except: [
'login',
]);
$middleware->append([
CheckForMaintenanceMode::class,
TrimStrings::class,
TrustProxies::class,
ConfigMiddleware::class,
]);
$middleware->web([
EncryptCookies::class,
PreventRequestForgery::class,
]);
$middleware->statefulApi();
$middleware->throttleApi('180,1');
$middleware->replace(Illuminate\Http\Middleware\TrustProxies::class, TrustProxies::class);
$middleware->replaceInGroup('web', Illuminate\Cookie\Middleware\EncryptCookies::class, EncryptCookies::class);
$middleware->alias([
'auth' => Authenticate::class,
'bindings' => SubstituteBindings::class,
'bouncer' => ScopeBouncer::class,
'company' => CompanyMiddleware::class,
'cron-job' => CronJobMiddleware::class,
'customer' => CustomerRedirectIfAuthenticated::class,
'customer-guest' => CustomerGuest::class,
'customer-portal' => CustomerPortalMiddleware::class,
'guest' => RedirectIfAuthenticated::class,
'install' => InstallationMiddleware::class,
'pdf-auth' => PdfMiddleware::class,
'redirect-if-installed' => RedirectIfInstalled::class,
'redirect-if-unauthenticated' => RedirectIfUnauthorized::class,
]);
$middleware->priority([
StartSession::class,
ShareErrorsFromSession::class,
Authenticate::class,
AuthenticateSession::class,
SubstituteBindings::class,
Authorize::class,
]);
})
->withExceptions(function (Exceptions $exceptions) {
//
})->create();