У меня есть контроллер, и в моем контроллере есть функция индекса, которая возвращает данные обратно пользователю.
Пользователь может отфильтровать запрос, который он хочет вернуть функции индекса.
Я заметил, что только маршруты с промежуточным программным обеспечением auth:api
возвращали пользовательский объект, когда я пытался вызвать Auth::user()
.
Теперь моя функция возвращает все события в моей базе данных.Пользователь может отфильтровать результаты как этот ?filter=my
, чтобы вернуть список событий, которые они создали.Проблема здесь заключается в том, что пользователь должен войти в систему, прежде чем он сможет увидеть созданные им события.
Моя проблема в том, что если я оберну этот маршрут с auth:api
, то гостевые пользователи не смогут его использовать.Однако, если я этого не сделаю, то этот конкретный фильтр, требующий входа пользователя, всегда будет возвращаться пустым.
Это мой контроллер:
public function index(Request $request)
{
$categoryId = $request->get("category_id");
$userId = Auth::check() ? Auth::user()->id : 0;
$filter = $request->get("filter");
$keyword = $request->get("keyword");
$events = Event::with(["category", "organisers", "banners", "schedules.ticketTypes", "schedules.venue", "schedules.programme"])
->when(!empty($categoryId), function ($query) use ($categoryId) {
return $query->where("category_id", $categoryId);
})
->whereNull("suspended_at")
->when($filter == "popular", function ($query) use ($categoryId) {
return $query->orderBy("views", "DESC")
->limit(15);
})
->when($filter == "upcoming", function ($query) {
return $query->whereHas("schedules", function ($query) {
$query->where("date", ">=", Carbon::now())
->where("date", "<", Carbon::now()->addDays(14))
->limit(15);
});
})
/* This part requires the auth:api middleware since I will be querying based on the user's id which I will get from the auth token passed in thee header.*/
->when($filter == "my", function ($query) use ($userId) {
return $query->whereHas("organisers", function ($query) use ($userId) {
$query->where("id", $userId)
->limit(15);
});
})
->when($filter == "search" && !empty($keyword), function ($query) use ($keyword) {
return $query->where("slug", "LIKE", "%" . $keyword . "%");
})
->get();
return EventResource::collection($events);
}
Это мое Ядро.php:
<?php
namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;
class Kernel extends HttpKernel
{
/**
* The application's global HTTP middleware stack.
*
* These middleware are run during every request to your application.
*
* @var array
*/
protected $middleware = [
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
\App\Http\Middleware\TrimStrings::class,
\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
\App\Http\Middleware\TrustProxies::class,
\Barryvdh\Cors\HandleCors::class,
];
/**
* The application's route middleware groups.
*
* @var array
*/
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
// \Illuminate\Session\Middleware\AuthenticateSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
'api' => [
'throttle:60,1',
'bindings',
],
];
/**
* The application's route middleware.
*
* These middleware may be assigned to groups or used individually.
*
* @var array
*/
protected $routeMiddleware = [
'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
'can' => \Illuminate\Auth\Middleware\Authorize::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
'acl' => \Kodeine\Acl\Middleware\HasPermission::class
];
}
Таким образом, моя индексная функция не требует входа пользователя в систему для доступа к ней.Однако, когда вы передаете фильтр ?filter=my
в URL, пользователь должен войти в систему для возврата данных, так как функция будет возвращать результаты на основе идентификатора пользователя.
Редактировать: ранее в подобных ситуациях я использовал промежуточное программное обеспечение jwt.check , когда использовал пакет tymon / jwt-auth.Однако, похоже, нет паспортного эквивалента.