|
| 1 | +<?php |
| 2 | + |
| 3 | +declare(strict_types=1); |
| 4 | + |
| 5 | +namespace App\Http\Controllers; |
| 6 | + |
| 7 | +use App\Models\TeamInvitation; |
| 8 | +use App\Models\User; |
| 9 | +use Illuminate\Http\RedirectResponse; |
| 10 | +use Illuminate\Http\Request; |
| 11 | +use Illuminate\Support\Facades\Log; |
| 12 | +use Illuminate\View\View; |
| 13 | +use Laravel\Jetstream\Contracts\AddsTeamMembers; |
| 14 | + |
| 15 | +final readonly class AcceptTeamInvitationController |
| 16 | +{ |
| 17 | + public function __invoke(Request $request, string $invitationId): RedirectResponse|View |
| 18 | + { |
| 19 | + $invitation = TeamInvitation::query()->whereKey($invitationId)->firstOrFail(); |
| 20 | + |
| 21 | + if ($invitation->isExpired()) { |
| 22 | + Log::warning('Expired invitation accessed', [ |
| 23 | + 'invitation_id' => $invitation->id, |
| 24 | + 'team_id' => $invitation->team_id, |
| 25 | + ]); |
| 26 | + |
| 27 | + return view('teams.invitation-expired'); |
| 28 | + } |
| 29 | + |
| 30 | + if ($request->user()->email !== $invitation->email) { |
| 31 | + Log::warning('Invitation email mismatch', [ |
| 32 | + 'invitation_id' => $invitation->id, |
| 33 | + 'user_id' => $request->user()->id, |
| 34 | + ]); |
| 35 | + |
| 36 | + abort(403, __('This invitation was sent to a different email address.')); |
| 37 | + } |
| 38 | + |
| 39 | + /** @var User $owner */ |
| 40 | + $owner = $invitation->team->owner; |
| 41 | + |
| 42 | + resolve(AddsTeamMembers::class)->add( |
| 43 | + $owner, |
| 44 | + $invitation->team, |
| 45 | + $invitation->email, |
| 46 | + $invitation->role, |
| 47 | + ); |
| 48 | + |
| 49 | + $invitation->delete(); |
| 50 | + |
| 51 | + /** @var User $user */ |
| 52 | + $user = $request->user(); |
| 53 | + $user->switchTeam($invitation->team); |
| 54 | + |
| 55 | + return redirect(config('fortify.home')) |
| 56 | + ->banner(__('Great! You have accepted the invitation to join the :team team.', [ // @phpstan-ignore method.notFound |
| 57 | + 'team' => $invitation->team->name, |
| 58 | + ])); |
| 59 | + } |
| 60 | +} |
0 commit comments