2024-12-09 10:10:35 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
|
|
|
|
|
|
use Closure;
|
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
|
|
|
|
|
class ApiSensitiveData
|
|
|
|
|
{
|
|
|
|
|
public function handle(Request $request, Closure $next)
|
|
|
|
|
{
|
|
|
|
|
$token = $request->user()->currentAccessToken();
|
2026-02-27 10:41:01 +00:00
|
|
|
$hasTokenPermission = $token->can('root') || $token->can('read:sensitive');
|
|
|
|
|
$teamId = (int) data_get($token, 'team_id');
|
|
|
|
|
$isAdmin = $teamId ? $request->user()->isAdminOfTeam($teamId) : false;
|
2024-12-09 10:10:35 +00:00
|
|
|
|
2026-02-27 10:41:01 +00:00
|
|
|
// Allow access to sensitive data only if token has permission AND user is admin/owner
|
2024-12-09 10:10:35 +00:00
|
|
|
$request->attributes->add([
|
2026-02-27 10:41:01 +00:00
|
|
|
'can_read_sensitive' => $hasTokenPermission && $isAdmin,
|
2024-12-09 10:10:35 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
return $next($request);
|
|
|
|
|
}
|
|
|
|
|
}
|