mirror of
https://github.com/axeloz/filesharing.git
synced 2025-05-06 10:03:55 +02:00
Improve authentication check
This commit is contained in:
parent
1e058ab2b0
commit
5a003c316a
1 changed files with 18 additions and 8 deletions
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue