Files
InvoiceShelf/bootstrap/app.php
Darko Gjorgjijoski 9432da467e Add super-admin Administration section and restructure global vs company settings
- Add Administration sidebar section (super-admin only) with Companies, Users, and Global Settings pages
- Add super-admin middleware, controllers, and API routes under /api/v1/super-admin/
- Allow super-admins to manage all companies and users across tenants
- Add user impersonation with short-lived tokens, audit logging, and UI banner
- Move system-level settings (Mail, PDF, Backup, Update, File Disk) from per-company to Administration > Global Settings
- Convert save_pdf_to_disk from CompanySetting to global Setting
- Add per-company mail configuration overrides (optional, falls back to global)
- Add CompanyMailConfigService to apply company mail config before sending emails
2026-04-03 10:35:40 +02:00

101 lines
3.7 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\SuperAdminMiddleware;
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,
'super-admin' => SuperAdminMiddleware::class,
]);
$middleware->priority([
StartSession::class,
ShareErrorsFromSession::class,
Authenticate::class,
AuthenticateSession::class,
SubstituteBindings::class,
Authorize::class,
]);
})
->withExceptions(function (Exceptions $exceptions) {
//
})->create();