mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-11-05 03:40:19 +00:00
Kernel middleware in separate commit.
This commit is contained in:
@@ -1,62 +1,11 @@
|
|||||||
<?php
|
<?php
|
||||||
/**
|
|
||||||
* Kernel.php
|
|
||||||
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
||||||
*
|
|
||||||
* This software may be modified and distributed under the terms of the
|
|
||||||
* Creative Commons Attribution-ShareAlike 4.0 International License.
|
|
||||||
*
|
|
||||||
* See the LICENSE file for details.
|
|
||||||
*/
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace FireflyIII\Http;
|
namespace FireflyIII\Http;
|
||||||
|
|
||||||
use FireflyIII\Http\Middleware\Authenticate;
|
|
||||||
use FireflyIII\Http\Middleware\AuthenticateTwoFactor;
|
|
||||||
use FireflyIII\Http\Middleware\Binder;
|
|
||||||
use FireflyIII\Http\Middleware\EncryptCookies;
|
|
||||||
use FireflyIII\Http\Middleware\IsAdmin;
|
|
||||||
use FireflyIII\Http\Middleware\Range;
|
|
||||||
use FireflyIII\Http\Middleware\RedirectIfAuthenticated;
|
|
||||||
use FireflyIII\Http\Middleware\RedirectIfTwoFactorAuthenticated;
|
|
||||||
use FireflyIII\Http\Middleware\Sandstorm;
|
|
||||||
use FireflyIII\Http\Middleware\StartFireflySession;
|
|
||||||
use FireflyIII\Http\Middleware\VerifyCsrfToken;
|
|
||||||
use Illuminate\Auth\Middleware\AuthenticateWithBasicAuth;
|
|
||||||
use Illuminate\Auth\Middleware\Authorize;
|
|
||||||
use Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse;
|
|
||||||
use Illuminate\Foundation\Http\Kernel as HttpKernel;
|
use Illuminate\Foundation\Http\Kernel as HttpKernel;
|
||||||
use Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode;
|
|
||||||
use Illuminate\Routing\Middleware\SubstituteBindings;
|
|
||||||
use Illuminate\Routing\Middleware\ThrottleRequests;
|
|
||||||
use Illuminate\View\Middleware\ShareErrorsFromSession;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class Kernel
|
|
||||||
*
|
|
||||||
* @package FireflyIII\Http
|
|
||||||
*/
|
|
||||||
class Kernel extends HttpKernel
|
class Kernel extends HttpKernel
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
|
||||||
* The bootstrap classes for the application.
|
|
||||||
*
|
|
||||||
* Next upgrade verify these are the same.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $bootstrappers
|
|
||||||
= [
|
|
||||||
'Illuminate\Foundation\Bootstrap\LoadEnvironmentVariables',
|
|
||||||
'Illuminate\Foundation\Bootstrap\LoadConfiguration',
|
|
||||||
'Illuminate\Foundation\Bootstrap\HandleExceptions',
|
|
||||||
'Illuminate\Foundation\Bootstrap\RegisterFacades',
|
|
||||||
'Illuminate\Foundation\Bootstrap\RegisterProviders',
|
|
||||||
'Illuminate\Foundation\Bootstrap\BootProviders',
|
|
||||||
];
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The application's global HTTP middleware stack.
|
* The application's global HTTP middleware stack.
|
||||||
*
|
*
|
||||||
@@ -64,9 +13,12 @@ class Kernel extends HttpKernel
|
|||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected $middleware
|
protected $middleware = [
|
||||||
= [
|
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
|
||||||
CheckForMaintenanceMode::class,
|
\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
|
||||||
|
\FireflyIII\Http\Middleware\TrimStrings::class,
|
||||||
|
\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
|
||||||
|
\FireflyIII\Http\Middleware\TrustProxies::class,
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -74,100 +26,17 @@ class Kernel extends HttpKernel
|
|||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected $middlewareGroups
|
protected $middlewareGroups = [
|
||||||
= [
|
|
||||||
// does not check login
|
|
||||||
// does not check 2fa
|
|
||||||
// does not check activation
|
|
||||||
'web' => [
|
'web' => [
|
||||||
Sandstorm::class,
|
\FireflyIII\Http\Middleware\EncryptCookies::class,
|
||||||
EncryptCookies::class,
|
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
|
||||||
AddQueuedCookiesToResponse::class,
|
\Illuminate\Session\Middleware\StartSession::class,
|
||||||
StartFireflySession::class,
|
// \Illuminate\Session\Middleware\AuthenticateSession::class,
|
||||||
ShareErrorsFromSession::class,
|
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
|
||||||
VerifyCsrfToken::class,
|
\FireflyIII\Http\Middleware\VerifyCsrfToken::class,
|
||||||
SubstituteBindings::class,
|
\Illuminate\Routing\Middleware\SubstituteBindings::class,
|
||||||
],
|
],
|
||||||
|
|
||||||
|
|
||||||
// MUST NOT be logged in. Does not care about 2FA or confirmation.
|
|
||||||
'user-not-logged-in' => [
|
|
||||||
Sandstorm::class,
|
|
||||||
EncryptCookies::class,
|
|
||||||
AddQueuedCookiesToResponse::class,
|
|
||||||
StartFireflySession::class,
|
|
||||||
ShareErrorsFromSession::class,
|
|
||||||
VerifyCsrfToken::class,
|
|
||||||
SubstituteBindings::class,
|
|
||||||
RedirectIfAuthenticated::class,
|
|
||||||
],
|
|
||||||
// MUST be logged in.
|
|
||||||
// MUST NOT have 2FA
|
|
||||||
// don't care about confirmation:
|
|
||||||
'user-logged-in-no-2fa' => [
|
|
||||||
Sandstorm::class,
|
|
||||||
EncryptCookies::class,
|
|
||||||
AddQueuedCookiesToResponse::class,
|
|
||||||
StartFireflySession::class,
|
|
||||||
ShareErrorsFromSession::class,
|
|
||||||
VerifyCsrfToken::class,
|
|
||||||
SubstituteBindings::class,
|
|
||||||
Authenticate::class,
|
|
||||||
RedirectIfTwoFactorAuthenticated::class,
|
|
||||||
],
|
|
||||||
|
|
||||||
// MUST be logged in
|
|
||||||
// don't care about 2fa
|
|
||||||
// don't care about confirmation.
|
|
||||||
'user-simple-auth' => [
|
|
||||||
Sandstorm::class,
|
|
||||||
EncryptCookies::class,
|
|
||||||
AddQueuedCookiesToResponse::class,
|
|
||||||
StartFireflySession::class,
|
|
||||||
ShareErrorsFromSession::class,
|
|
||||||
VerifyCsrfToken::class,
|
|
||||||
SubstituteBindings::class,
|
|
||||||
Authenticate::class,
|
|
||||||
],
|
|
||||||
|
|
||||||
// MUST be logged in
|
|
||||||
// MUST have 2fa
|
|
||||||
// MUST be confirmed.
|
|
||||||
// (this group includes the other Firefly middleware)
|
|
||||||
'user-full-auth' => [
|
|
||||||
Sandstorm::class,
|
|
||||||
EncryptCookies::class,
|
|
||||||
AddQueuedCookiesToResponse::class,
|
|
||||||
StartFireflySession::class,
|
|
||||||
ShareErrorsFromSession::class,
|
|
||||||
VerifyCsrfToken::class,
|
|
||||||
SubstituteBindings::class,
|
|
||||||
Authenticate::class,
|
|
||||||
AuthenticateTwoFactor::class,
|
|
||||||
Range::class,
|
|
||||||
Binder::class,
|
|
||||||
],
|
|
||||||
// MUST be logged in
|
|
||||||
// MUST have 2fa
|
|
||||||
// MUST be confirmed.
|
|
||||||
// MUST have owner role
|
|
||||||
// (this group includes the other Firefly middleware)
|
|
||||||
'admin' => [
|
|
||||||
Sandstorm::class,
|
|
||||||
EncryptCookies::class,
|
|
||||||
AddQueuedCookiesToResponse::class,
|
|
||||||
StartFireflySession::class,
|
|
||||||
ShareErrorsFromSession::class,
|
|
||||||
VerifyCsrfToken::class,
|
|
||||||
SubstituteBindings::class,
|
|
||||||
Authenticate::class,
|
|
||||||
AuthenticateTwoFactor::class,
|
|
||||||
IsAdmin::class,
|
|
||||||
Range::class,
|
|
||||||
Binder::class,
|
|
||||||
],
|
|
||||||
|
|
||||||
|
|
||||||
'api' => [
|
'api' => [
|
||||||
'throttle:60,1',
|
'throttle:60,1',
|
||||||
'bindings',
|
'bindings',
|
||||||
@@ -181,14 +50,12 @@ class Kernel extends HttpKernel
|
|||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected $routeMiddleware
|
protected $routeMiddleware = [
|
||||||
= [
|
'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
|
||||||
'auth' => Authenticate::class,
|
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
|
||||||
'auth.basic' => AuthenticateWithBasicAuth::class,
|
'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
|
||||||
'bindings' => SubstituteBindings::class,
|
'can' => \Illuminate\Auth\Middleware\Authorize::class,
|
||||||
'can' => Authorize::class,
|
'guest' => \FireflyIII\Http\Middleware\RedirectIfAuthenticated::class,
|
||||||
'guest' => RedirectIfAuthenticated::class,
|
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
|
||||||
'throttle' => ThrottleRequests::class,
|
|
||||||
'range' => Range::class,
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,33 +1,17 @@
|
|||||||
<?php
|
<?php
|
||||||
/**
|
|
||||||
* EncryptCookies.php
|
|
||||||
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
||||||
*
|
|
||||||
* This software may be modified and distributed under the terms of the
|
|
||||||
* Creative Commons Attribution-ShareAlike 4.0 International License.
|
|
||||||
*
|
|
||||||
* See the LICENSE file for details.
|
|
||||||
*/
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace FireflyIII\Http\Middleware;
|
namespace FireflyIII\Http\Middleware;
|
||||||
|
|
||||||
use Illuminate\Cookie\Middleware\EncryptCookies as BaseEncrypter;
|
use Illuminate\Cookie\Middleware\EncryptCookies as Middleware;
|
||||||
|
|
||||||
/**
|
class EncryptCookies extends Middleware
|
||||||
* Class EncryptCookies
|
|
||||||
*
|
|
||||||
* @package FireflyIII\Http\Middleware
|
|
||||||
*/
|
|
||||||
class EncryptCookies extends BaseEncrypter
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* The names of the cookies that should not be encrypted.
|
* The names of the cookies that should not be encrypted.
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected $except
|
protected $except = [
|
||||||
= [
|
|
||||||
//
|
//
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,25 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
/**
|
|
||||||
* RedirectIfAuthenticated.php
|
|
||||||
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
||||||
*
|
|
||||||
* This software may be modified and distributed under the terms of the
|
|
||||||
* Creative Commons Attribution-ShareAlike 4.0 International License.
|
|
||||||
*
|
|
||||||
* See the LICENSE file for details.
|
|
||||||
*/
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace FireflyIII\Http\Middleware;
|
namespace FireflyIII\Http\Middleware;
|
||||||
|
|
||||||
use Closure;
|
use Closure;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
|
||||||
/**
|
|
||||||
* Class RedirectIfAuthenticated
|
|
||||||
*
|
|
||||||
* @package FireflyIII\Http\Middleware
|
|
||||||
*/
|
|
||||||
class RedirectIfAuthenticated
|
class RedirectIfAuthenticated
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
@@ -28,13 +13,12 @@ class RedirectIfAuthenticated
|
|||||||
* @param \Illuminate\Http\Request $request
|
* @param \Illuminate\Http\Request $request
|
||||||
* @param \Closure $next
|
* @param \Closure $next
|
||||||
* @param string|null $guard
|
* @param string|null $guard
|
||||||
*
|
|
||||||
* @return mixed
|
* @return mixed
|
||||||
*/
|
*/
|
||||||
public function handle($request, Closure $next, $guard = null)
|
public function handle($request, Closure $next, $guard = null)
|
||||||
{
|
{
|
||||||
if (Auth::guard($guard)->check()) {
|
if (Auth::guard($guard)->check()) {
|
||||||
return redirect('/');
|
return redirect('/home');
|
||||||
}
|
}
|
||||||
|
|
||||||
return $next($request);
|
return $next($request);
|
||||||
|
|||||||
18
app/Http/Middleware/TrimStrings.php
Normal file
18
app/Http/Middleware/TrimStrings.php
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace FireflyIII\Http\Middleware;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\Middleware\TrimStrings as Middleware;
|
||||||
|
|
||||||
|
class TrimStrings extends Middleware
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The names of the attributes that should not be trimmed.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $except = [
|
||||||
|
'password',
|
||||||
|
'password_confirmation',
|
||||||
|
];
|
||||||
|
}
|
||||||
29
app/Http/Middleware/TrustProxies.php
Normal file
29
app/Http/Middleware/TrustProxies.php
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace FireflyIII\Http\Middleware;
|
||||||
|
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Fideloper\Proxy\TrustProxies as Middleware;
|
||||||
|
|
||||||
|
class TrustProxies extends Middleware
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The trusted proxies for this application.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $proxies;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The current proxy header mappings.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $headers = [
|
||||||
|
Request::HEADER_FORWARDED => 'FORWARDED',
|
||||||
|
Request::HEADER_X_FORWARDED_FOR => 'X_FORWARDED_FOR',
|
||||||
|
Request::HEADER_X_FORWARDED_HOST => 'X_FORWARDED_HOST',
|
||||||
|
Request::HEADER_X_FORWARDED_PORT => 'X_FORWARDED_PORT',
|
||||||
|
Request::HEADER_X_FORWARDED_PROTO => 'X_FORWARDED_PROTO',
|
||||||
|
];
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user