filesharing/app/Http/Middleware/UploadAccess.php

43 lines
960 B
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
use App\Helpers\Upload;
use Illuminate\Support\Facades\Storage;
class UploadAccess
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle(Request $request, Closure $next): Response
{
// Checking IP based access
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()) {
abort(401);
}
else {
return response()->view('login');
}
}
}