add guest invitation read & valide with route
This commit is contained in:
@@ -5,6 +5,7 @@ namespace App\Http\Controllers;
|
||||
use App\Http\Requests\EventRequest;
|
||||
use App\Models\Event;
|
||||
use App\Http\Resources\Event as EventResource;
|
||||
use App\Models\EventGuestsNonUsers;
|
||||
use App\User;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
@@ -150,4 +151,39 @@ class EventController extends Controller
|
||||
|
||||
return response([], 204);
|
||||
}
|
||||
|
||||
public function addGuestWithEmail(Event $event)
|
||||
{
|
||||
$data = request()->validate([
|
||||
'email' => 'required|email',
|
||||
]);
|
||||
|
||||
$event->emailedGuests()->save(new EventGuestsNonUsers(['email' => $data['email']]));
|
||||
|
||||
return (new EventResource($event))
|
||||
->response()
|
||||
->setStatusCode(201);
|
||||
}
|
||||
|
||||
public function guestCanReadEvent(Event $event)
|
||||
{
|
||||
$guest = request()->guest;
|
||||
|
||||
if (!$guest->read_at) {
|
||||
$guest->update(['read_at' => now()->toDateTimeString()]);
|
||||
}
|
||||
return (new EventResource($event))
|
||||
->response()
|
||||
->setStatusCode(200);
|
||||
}
|
||||
|
||||
public function guestCanConfirmEvent(Event $event)
|
||||
{
|
||||
$guest = request()->guest;
|
||||
$guest->update(['validated_at' => now()->toDateTimeString()]);
|
||||
|
||||
return (new EventResource($event))
|
||||
->response()
|
||||
->setStatusCode(200);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -63,5 +63,6 @@ class Kernel extends HttpKernel
|
||||
'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
|
||||
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
|
||||
'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
|
||||
'guest-mail' => \App\Http\Middleware\EventGuestWithEmail::class,
|
||||
];
|
||||
}
|
||||
|
||||
32
app/Http/Middleware/EventGuestWithEmail.php
Normal file
32
app/Http/Middleware/EventGuestWithEmail.php
Normal file
@@ -0,0 +1,32 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Middleware;
|
||||
|
||||
use App\Models\EventGuestsNonUsers;
|
||||
use Closure;
|
||||
|
||||
class EventGuestWithEmail
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure $next
|
||||
* @return mixed
|
||||
*/
|
||||
public function handle($request, Closure $next)
|
||||
{
|
||||
$data = request()->validate([
|
||||
'email' => 'required|email',
|
||||
'token' => 'required|uuid',
|
||||
]);
|
||||
|
||||
$guest = EventGuestsNonUsers::where('email', $data['email'])->where('token', $data['token'])->first();
|
||||
if ($guest) {
|
||||
$request->guest = $guest;
|
||||
return $next($request);
|
||||
}
|
||||
|
||||
return response([], 403);
|
||||
}
|
||||
}
|
||||
@@ -3,6 +3,7 @@
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use App\Http\Resources\User as UserResource;
|
||||
use App\Http\Resources\EventGuestWithoutEmail as GuestsWithoutEmailResource;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class Event extends JsonResource
|
||||
@@ -32,6 +33,9 @@ class Event extends JsonResource
|
||||
],
|
||||
],
|
||||
'invitations' => UserResource::collection($this->guests),
|
||||
'invitations-with-email' => [
|
||||
'data' => GuestsWithoutEmailResource::collection($this->emailedGuests)
|
||||
],
|
||||
]
|
||||
],
|
||||
],
|
||||
|
||||
23
app/Http/Resources/EventGuestWithoutEmail.php
Normal file
23
app/Http/Resources/EventGuestWithoutEmail.php
Normal file
@@ -0,0 +1,23 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class EventGuestWithoutEmail extends JsonResource
|
||||
{
|
||||
/**
|
||||
* Transform the resource into an array.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function toArray($request)
|
||||
{
|
||||
return [
|
||||
'email' => $this->email,
|
||||
'read_at' => $this->read_at,
|
||||
'validated_at' => $this->validated_at,
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -5,6 +5,7 @@ namespace App\Models;
|
||||
use App\User;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
|
||||
use Illuminate\Database\Eloquent\Relations\HasMany;
|
||||
|
||||
class Event extends Model
|
||||
{
|
||||
@@ -16,4 +17,9 @@ class Event extends Model
|
||||
->withPivot('is_staff', 'validated_at')
|
||||
->withTimestamps();
|
||||
}
|
||||
|
||||
public function emailedGuests() :HasMany
|
||||
{
|
||||
return $this->hasMany(EventGuestsNonUsers::class, 'event_id');
|
||||
}
|
||||
}
|
||||
|
||||
12
app/Models/EventGuestsNonUsers.php
Normal file
12
app/Models/EventGuestsNonUsers.php
Normal file
@@ -0,0 +1,12 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class EventGuestsNonUsers extends Model
|
||||
{
|
||||
protected $table = 'event_non_user_guests';
|
||||
|
||||
protected $guarded = [];
|
||||
}
|
||||
Reference in New Issue
Block a user