2024-09-20 10:50:25 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
|
|
|
|
use App\Facades\Settings;
|
|
|
|
use App\Models\User;
|
|
|
|
use Closure;
|
|
|
|
use Illuminate\Http\Response;
|
|
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
|
|
|
|
class RejectIfSsoOnlyAndNotForAdmin
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Reject the request when it aims to modify or impact a user account in those 2 conditions:
|
|
|
|
* - The impacted account does not have the Administrator role
|
|
|
|
* - Authentication is restricted to SSO only
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function handle($request, Closure $next)
|
|
|
|
{
|
|
|
|
if (Settings::get('useSsoOnly')) {
|
|
|
|
if ($email = $request->input('email', null)) {
|
|
|
|
$user = User::whereEmail($email)->first();
|
2024-09-26 23:50:01 +02:00
|
|
|
} else {
|
|
|
|
$user = Auth::user();
|
2024-09-20 10:50:25 +02:00
|
|
|
}
|
2024-09-26 23:50:01 +02:00
|
|
|
|
2024-09-20 10:50:25 +02:00
|
|
|
if ($user?->isAdministrator()) {
|
|
|
|
return $next($request);
|
|
|
|
}
|
2024-09-26 23:50:01 +02:00
|
|
|
|
2024-09-20 10:50:25 +02:00
|
|
|
Log::notice(sprintf('Request to %s rejected, only Admins can request it while authentication is restricted to SSO only', $request->getPathInfo()));
|
2024-09-26 23:50:01 +02:00
|
|
|
|
2024-09-20 10:50:25 +02:00
|
|
|
return response()->json(['message' => __('errors.unsupported_with_sso_only')], Response::HTTP_METHOD_NOT_ALLOWED);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $next($request);
|
|
|
|
}
|
|
|
|
}
|