增加 资源所有者验证
This commit is contained in:
parent
7f7167a5d3
commit
186cbb6dcc
@ -12,6 +12,7 @@
|
|||||||
use App\Http\Middleware\RealNamed;
|
use App\Http\Middleware\RealNamed;
|
||||||
use App\Http\Middleware\RedirectIfAuthenticated;
|
use App\Http\Middleware\RedirectIfAuthenticated;
|
||||||
use App\Http\Middleware\ReportRequestToCluster;
|
use App\Http\Middleware\ReportRequestToCluster;
|
||||||
|
use App\Http\Middleware\ResourceOwner;
|
||||||
use App\Http\Middleware\TrimStrings;
|
use App\Http\Middleware\TrimStrings;
|
||||||
use App\Http\Middleware\TrustedDomain;
|
use App\Http\Middleware\TrustedDomain;
|
||||||
use App\Http\Middleware\TrustProxies;
|
use App\Http\Middleware\TrustProxies;
|
||||||
@ -107,5 +108,6 @@ class Kernel extends HttpKernel
|
|||||||
'banned' => ValidateUserIfBanned::class,
|
'banned' => ValidateUserIfBanned::class,
|
||||||
'admin.validateReferer' => ValidateReferer::class,
|
'admin.validateReferer' => ValidateReferer::class,
|
||||||
'real_named' => RealNamed::class,
|
'real_named' => RealNamed::class,
|
||||||
|
'resource_owner' => ResourceOwner::class,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
28
app/Http/Middleware/ResourceOwner.php
Normal file
28
app/Http/Middleware/ResourceOwner.php
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Middleware;
|
||||||
|
|
||||||
|
use Closure;
|
||||||
|
use Illuminate\Http\RedirectResponse;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
|
||||||
|
class ResourceOwner
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Handle an incoming request.
|
||||||
|
*/
|
||||||
|
public function handle(Request $request, Closure $next, $model): Response|RedirectResponse
|
||||||
|
{
|
||||||
|
$model = $request->route($model);
|
||||||
|
|
||||||
|
if ($model && isset($model->user_id) && $request->user()) {
|
||||||
|
// if module has user_id and user is logined
|
||||||
|
if ($model->user_id != $request->user()->id) {
|
||||||
|
abort(403);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $next($request);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user