mirror of
https://github.com/HolgerHatGarKeineNode/einundzwanzig-app.git
synced 2026-06-17 16:40:31 +00:00
119deb4f5c
- 🔒 Introduce `addToMine` policy for authenticated users to add existing meetups. - ✏️ Add `addToMine` method in `MeetupController` with idempotent handling. - ✨ Include `addMember` utility in `Meetup` model for managing pivot relationships. - 🛠️ Refactor `AddMeetupToMineTool` to use `addMember` for consistency. - 🧪 Add feature tests for `addToMine`, covering idempotency, permissions, and unknown slugs. - 🌐 Register `addToMine` route in API and link it to `MeetupController`.
63 lines
2.2 KiB
PHP
63 lines
2.2 KiB
PHP
<?php
|
||
|
||
namespace App\Mcp\Tools\Meetup;
|
||
|
||
use App\Http\Resources\MeetupResource;
|
||
use App\Mcp\Tools\Concerns\ResolvesEntities;
|
||
use App\Models\Meetup;
|
||
use Illuminate\Contracts\JsonSchema\JsonSchema;
|
||
use Illuminate\JsonSchema\Types\Type;
|
||
use Laravel\Mcp\Request;
|
||
use Laravel\Mcp\Response;
|
||
use Laravel\Mcp\Server\Attributes\Description;
|
||
use Laravel\Mcp\Server\Tool;
|
||
|
||
#[Description('Fügt ein bereits bestehendes Meetup (per Name angegeben) zu „Meine Meetups" hinzu, sodass es in der eigenen Liste erscheint und Termine dazu angelegt werden können. Macht den Nutzer zum Mitglied – die Stammdaten (Name, Stadt, Links) bleiben dem ursprünglichen Ersteller vorbehalten. Vorher mit search-meetups den genauen Namen ermitteln.')]
|
||
class AddMeetupToMineTool extends Tool
|
||
{
|
||
use ResolvesEntities;
|
||
|
||
public function handle(Request $request): Response
|
||
{
|
||
$user = $request->user();
|
||
|
||
if ($user === null) {
|
||
return Response::error('Nicht authentifiziert.');
|
||
}
|
||
|
||
if ($this->present($request->get('meetup_id'))) {
|
||
$meetup = Meetup::find($request->get('meetup_id'));
|
||
|
||
if ($meetup === null) {
|
||
return Response::error('Meetup nicht gefunden.');
|
||
}
|
||
} else {
|
||
$meetup = $this->resolveGlobalByName(Meetup::query(), $request->get('meetup'), 'Meetups');
|
||
|
||
if ($meetup instanceof Response) {
|
||
return $meetup;
|
||
}
|
||
}
|
||
|
||
$wasAdded = $meetup->addMember($user);
|
||
|
||
return Response::json([
|
||
'meetup' => MeetupResource::make($meetup)->resolve(),
|
||
'message' => $wasAdded
|
||
? '„'.$meetup->name.'" wurde zu deinen Meetups hinzugefügt.'
|
||
: '„'.$meetup->name.'" war bereits Teil deiner Meetups.',
|
||
]);
|
||
}
|
||
|
||
/**
|
||
* @return array<string, Type>
|
||
*/
|
||
public function schema(JsonSchema $schema): array
|
||
{
|
||
return [
|
||
'meetup' => $schema->string()->description('Name des bestehenden Meetups, das hinzugefügt werden soll (vorher per search-meetups ermitteln).'),
|
||
'meetup_id' => $schema->integer()->description('Optional: ID des Meetups, falls bereits bekannt (Alternative zu "meetup").'),
|
||
];
|
||
}
|
||
}
|