mirror of
https://github.com/coollabsio/coolify.git
synced 2026-06-14 03:19:51 +00:00
38 lines
1.0 KiB
PHP
38 lines
1.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
use Closure;
|
|
use Illuminate\Http\Request;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
class EnsureTokenBelongsToCurrentTeamMember
|
|
{
|
|
public function handle(Request $request, Closure $next): Response
|
|
{
|
|
$user = $request->user();
|
|
$token = $user?->currentAccessToken();
|
|
$teamId = $token?->team_id;
|
|
|
|
if (! $user || ! $token || is_null($teamId)) {
|
|
return response()->json(['message' => 'Invalid token.'], 401);
|
|
}
|
|
|
|
$team = $user->teams()
|
|
->where('teams.id', $teamId)
|
|
->first();
|
|
|
|
if (! $team) {
|
|
return response()->json(['message' => 'Invalid token.'], 401);
|
|
}
|
|
|
|
$role = $team->pivot?->role;
|
|
if (($token->can('root') || $token->can('write') || $token->can('write:sensitive'))
|
|
&& ! in_array($role, ['admin', 'owner'], true)) {
|
|
return response()->json(['message' => 'Missing required team role.'], 403);
|
|
}
|
|
|
|
return $next($request);
|
|
}
|
|
}
|