Improve authentication check

This commit is contained in:
Axel 2023-05-18 10:50:58 +02:00
parent 1e058ab2b0
commit 5a003c316a
Signed by: axel
GPG key ID: 73C0A5961B6BC740

View file

@ -6,6 +6,7 @@ use Closure;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response; use Symfony\Component\HttpFoundation\Response;
use App\Helpers\Upload; use App\Helpers\Upload;
use Illuminate\Support\Facades\Storage;
class UploadAccess class UploadAccess
{ {
@ -18,8 +19,20 @@ class UploadAccess
*/ */
public function handle(Request $request, Closure $next): Response public function handle(Request $request, Closure $next): Response
{ {
if ($request->session()->missing('authenticated') && Upload::canUpload($request->ip()) !== true) { // Checking IP based access
//return redirect('login'); if (Upload::canUpload($request->ip()) === true) {
return $next($request);
}
// Checking credentials auth
if ($request->session()->get('authenticated', false) === true && $request->session()->has('login')) {
// If user still exists
if (Storage::disk('users')->exists($request->session()->get('login').'.json')) {
return $next($request);
}
}
// Fallback, authentication required
if ($request->ajax()) { if ($request->ajax()) {
abort(401); abort(401);
} }
@ -27,7 +40,4 @@ class UploadAccess
return response()->view('login'); return response()->view('login');
} }
} }
return $next($request);
}
} }