2015-02-06 04:39:52 +01:00
|
|
|
<?php
|
2017-12-10 09:02:26 +01:00
|
|
|
/**
|
|
|
|
|
* app.php
|
2020-03-17 16:06:30 +00:00
|
|
|
* Copyright (c) 2019 james@firefly-iii.org.
|
2017-12-10 09:02:26 +01:00
|
|
|
*
|
2019-10-02 06:38:00 +02:00
|
|
|
* This file is part of Firefly III (https://github.com/firefly-iii).
|
2017-12-10 09:02:26 +01:00
|
|
|
*
|
2019-10-02 06:38:00 +02:00
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
|
* License, or (at your option) any later version.
|
2017-12-10 09:02:26 +01:00
|
|
|
*
|
2019-10-02 06:38:00 +02:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
2017-12-10 09:02:26 +01:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2019-10-02 06:38:00 +02:00
|
|
|
* GNU Affero General Public License for more details.
|
2017-12-10 09:02:26 +01:00
|
|
|
*
|
2019-10-02 06:38:00 +02:00
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2017-12-10 09:02:26 +01:00
|
|
|
*/
|
|
|
|
|
|
2017-09-14 17:40:02 +02:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
2025-05-27 17:09:35 +02:00
|
|
|
use FireflyIII\Exceptions\Handler;
|
2026-01-24 20:36:20 +01:00
|
|
|
use FireflyIII\Http\Middleware\AcceptHeaders;
|
|
|
|
|
use FireflyIII\Http\Middleware\Authenticate;
|
|
|
|
|
use FireflyIII\Http\Middleware\Binder;
|
|
|
|
|
use FireflyIII\Http\Middleware\EncryptCookies;
|
|
|
|
|
use FireflyIII\Http\Middleware\Installer;
|
|
|
|
|
use FireflyIII\Http\Middleware\InterestingMessage;
|
|
|
|
|
use FireflyIII\Http\Middleware\IsAdmin;
|
|
|
|
|
use FireflyIII\Http\Middleware\Range;
|
|
|
|
|
use FireflyIII\Http\Middleware\RedirectIfAuthenticated;
|
2026-01-25 17:27:27 +01:00
|
|
|
use FireflyIII\Http\Middleware\SecureHeaders;
|
2026-01-24 20:36:20 +01:00
|
|
|
use FireflyIII\Http\Middleware\StartFireflySession;
|
2026-01-25 20:36:25 +01:00
|
|
|
use FireflyIII\Http\Middleware\TrustProxies;
|
2026-01-24 20:36:20 +01:00
|
|
|
use FireflyIII\Http\Middleware\VerifyCsrfToken;
|
|
|
|
|
use Illuminate\Contracts\Debug\ExceptionHandler;
|
|
|
|
|
use Illuminate\Contracts\Http\Kernel;
|
|
|
|
|
use Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse;
|
|
|
|
|
use Illuminate\Foundation\Application;
|
|
|
|
|
use Illuminate\Foundation\Configuration\Exceptions;
|
|
|
|
|
use Illuminate\Foundation\Configuration\Middleware;
|
2026-01-25 17:50:19 +01:00
|
|
|
use Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull;
|
|
|
|
|
use Illuminate\Foundation\Http\Middleware\InvokeDeferredCallbacks;
|
|
|
|
|
use Illuminate\Foundation\Http\Middleware\PreventRequestsDuringMaintenance;
|
|
|
|
|
use Illuminate\Foundation\Http\Middleware\TrimStrings;
|
|
|
|
|
use Illuminate\Http\Middleware\HandleCors;
|
|
|
|
|
use Illuminate\Http\Middleware\ValidatePostSize;
|
2026-01-25 20:13:53 +01:00
|
|
|
use Illuminate\Routing\Middleware\SubstituteBindings;
|
2026-01-24 20:36:20 +01:00
|
|
|
use Illuminate\View\Middleware\ShareErrorsFromSession;
|
|
|
|
|
use Laravel\Passport\Http\Middleware\CreateFreshApiToken;
|
|
|
|
|
use Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful;
|
|
|
|
|
use PragmaRX\Google2FALaravel\Middleware as MFAMiddleware;
|
2025-05-27 17:09:35 +02:00
|
|
|
|
2015-02-06 04:39:52 +01:00
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Create The Application
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
| The first thing we will do is create a new Laravel application instance
|
|
|
|
|
| which serves as the "glue" for all the components of Laravel, and is
|
2023-03-18 14:35:08 +01:00
|
|
|
| the IoC container for the system binding all the various parts.
|
2015-02-06 04:39:52 +01:00
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
2023-03-18 14:35:08 +01:00
|
|
|
bcscale(12);
|
2017-09-10 09:54:00 +02:00
|
|
|
|
2018-04-27 11:29:09 +02:00
|
|
|
if (!function_exists('envNonEmpty')) {
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @return mixed|null
|
|
|
|
|
*/
|
2024-03-10 06:17:31 +01:00
|
|
|
function envNonEmpty(string $key, string | int | bool | null $default = null)
|
2023-10-28 15:03:33 +02:00
|
|
|
{
|
2025-01-03 14:56:06 +01:00
|
|
|
$result = env($key, $default); // @phpstan-ignore-line
|
2023-10-30 06:17:38 +01:00
|
|
|
if ('' === $result) {
|
2025-05-27 17:09:35 +02:00
|
|
|
return $default;
|
2018-04-27 11:29:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $result;
|
2018-04-27 06:26:37 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-29 14:17:10 +02:00
|
|
|
if (!function_exists('stringIsEqual')) {
|
2023-10-28 15:03:33 +02:00
|
|
|
function stringIsEqual(string $left, string $right): bool
|
|
|
|
|
{
|
2020-08-22 12:24:01 +02:00
|
|
|
return $left === $right;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-01-24 20:36:20 +01:00
|
|
|
$app = Application::configure(basePath: dirname(__DIR__))
|
|
|
|
|
->withRouting(
|
|
|
|
|
web : __DIR__ . '/../routes/web.php',
|
|
|
|
|
commands: __DIR__ . '/../routes/console.php',
|
|
|
|
|
health : '/up',
|
|
|
|
|
)
|
|
|
|
|
->withMiddleware(function (Middleware $middleware): void {
|
2026-01-25 17:50:19 +01:00
|
|
|
// overrule the standard middleware
|
2026-01-25 20:13:53 +01:00
|
|
|
$middleware->use(
|
|
|
|
|
[
|
|
|
|
|
InvokeDeferredCallbacks::class,
|
|
|
|
|
HandleCors::class,
|
|
|
|
|
PreventRequestsDuringMaintenance::class,
|
|
|
|
|
ValidatePostSize::class,
|
|
|
|
|
TrimStrings::class,
|
|
|
|
|
ConvertEmptyStringsToNull::class,
|
|
|
|
|
SecureHeaders::class,
|
2026-01-25 20:36:25 +01:00
|
|
|
TrustProxies::class,
|
2026-01-25 20:13:53 +01:00
|
|
|
]
|
|
|
|
|
);
|
2026-01-25 09:02:47 +01:00
|
|
|
|
2026-01-25 17:50:19 +01:00
|
|
|
// overrule the web group
|
2026-01-25 20:13:53 +01:00
|
|
|
$middleware->group('web',
|
|
|
|
|
[
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
StartFireflySession::class,
|
|
|
|
|
ShareErrorsFromSession::class,
|
|
|
|
|
VerifyCsrfToken::class,
|
|
|
|
|
SubstituteBindings::class,
|
|
|
|
|
CreateFreshApiToken::class,
|
|
|
|
|
]
|
|
|
|
|
);
|
2026-01-24 20:36:20 +01:00
|
|
|
// new group?
|
2026-01-25 20:13:53 +01:00
|
|
|
$middleware->appendToGroup('binders-only',
|
|
|
|
|
[
|
|
|
|
|
Installer::class,
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
Binder::class,
|
|
|
|
|
]);
|
2026-01-24 20:36:20 +01:00
|
|
|
|
|
|
|
|
//
|
|
|
|
|
$middleware->appendToGroup('user-not-logged-in', [
|
|
|
|
|
Installer::class,
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
StartFireflySession::class,
|
|
|
|
|
ShareErrorsFromSession::class,
|
|
|
|
|
VerifyCsrfToken::class,
|
|
|
|
|
Binder::class,
|
|
|
|
|
RedirectIfAuthenticated::class,
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
// more
|
|
|
|
|
$middleware->appendToGroup('user-logged-in-no-2fa', [
|
|
|
|
|
Installer::class,
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
StartFireflySession::class,
|
|
|
|
|
ShareErrorsFromSession::class,
|
|
|
|
|
VerifyCsrfToken::class,
|
|
|
|
|
Binder::class,
|
|
|
|
|
Authenticate::class,
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
// simple auth
|
|
|
|
|
$middleware->appendToGroup('user-simple-auth', [
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
StartFireflySession::class,
|
|
|
|
|
ShareErrorsFromSession::class,
|
|
|
|
|
VerifyCsrfToken::class,
|
|
|
|
|
Binder::class,
|
|
|
|
|
Authenticate::class,
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
// user full auth
|
|
|
|
|
$middleware->appendToGroup('user-full-auth', [
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
StartFireflySession::class,
|
|
|
|
|
ShareErrorsFromSession::class,
|
|
|
|
|
VerifyCsrfToken::class,
|
|
|
|
|
Authenticate::class,
|
|
|
|
|
MFAMiddleware::class,
|
|
|
|
|
Range::class,
|
|
|
|
|
Binder::class,
|
|
|
|
|
InterestingMessage::class,
|
|
|
|
|
CreateFreshApiToken::class,
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
// admin
|
|
|
|
|
$middleware->appendToGroup('admin', [
|
|
|
|
|
EncryptCookies::class,
|
|
|
|
|
AddQueuedCookiesToResponse::class,
|
|
|
|
|
StartFireflySession::class,
|
|
|
|
|
ShareErrorsFromSession::class,
|
|
|
|
|
VerifyCsrfToken::class,
|
|
|
|
|
Authenticate::class,
|
|
|
|
|
// AuthenticateTwoFactor::class,
|
|
|
|
|
IsAdmin::class,
|
|
|
|
|
Range::class,
|
|
|
|
|
Binder::class,
|
|
|
|
|
CreateFreshApiToken::class,
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
// api
|
|
|
|
|
$middleware->appendToGroup('api', [AcceptHeaders::class, EnsureFrontendRequestsAreStateful::class, 'auth:api,sanctum', Binder::class]);
|
|
|
|
|
// api basic,
|
|
|
|
|
$middleware->appendToGroup('api_basic', [AcceptHeaders::class, Binder::class]);
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
->withEvents(discover: [
|
|
|
|
|
__DIR__ . '/../app/Listeners',
|
|
|
|
|
])
|
|
|
|
|
->withExceptions(function (Exceptions $exceptions): void {
|
|
|
|
|
//
|
|
|
|
|
})->create();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//$app->withEvents(discover: [
|
|
|
|
|
// __DIR__.'/../app/Domain/Orders/Listeners',
|
|
|
|
|
// ]);
|
2015-02-06 04:39:52 +01:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Bind Important Interfaces
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
| Next, we need to bind some important interfaces into the container so
|
|
|
|
|
| we will be able to resolve them when needed. The kernels serve the
|
|
|
|
|
| incoming requests to this application from both the web and CLI.
|
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
$app->singleton(
|
2025-05-27 17:09:35 +02:00
|
|
|
Kernel::class,
|
2016-01-08 14:28:15 +01:00
|
|
|
FireflyIII\Http\Kernel::class
|
2015-02-06 04:39:52 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
$app->singleton(
|
2016-01-08 14:28:15 +01:00
|
|
|
Illuminate\Contracts\Console\Kernel::class,
|
|
|
|
|
FireflyIII\Console\Kernel::class
|
2015-02-06 04:39:52 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
$app->singleton(
|
2025-05-27 17:09:35 +02:00
|
|
|
ExceptionHandler::class,
|
|
|
|
|
Handler::class
|
2015-02-06 04:39:52 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Return The Application
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
| This script returns the application instance. The instance is given to
|
|
|
|
|
| the calling script so we can separate the building of the instances
|
|
|
|
|
| from the actual running of the application and sending responses.
|
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
return $app;
|