QuickAppGetUserFromToken.php 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Closure;
  4. use Illuminate\Http\Request;
  5. use Tymon\JWTAuth\Exceptions\JWTException;
  6. use Tymon\JWTAuth\Exceptions\TokenExpiredException;
  7. use Tymon\JWTAuth\Middleware\BaseMiddleware;
  8. class QuickAppGetUserFromToken extends BaseMiddleware
  9. {
  10. /**
  11. * Handle an incoming request.
  12. *
  13. * @param \Illuminate\Http\Request $request
  14. * @param \Closure $next
  15. * @return mixed
  16. */
  17. public function handle(Request $request, Closure $next)
  18. {
  19. if (!$token = $this->auth->setRequest($request)->getToken()) {
  20. return response()->error('QAPP_TOKEN_ERROR');
  21. }
  22. try {
  23. $user = $this->auth->authenticate($token);
  24. } catch (TokenExpiredException $e) {
  25. return response()->error('QAPP_TOKEN_ERROR');
  26. } catch (JWTException $e) {
  27. return response()->error('QAPP_TOKEN_ERROR');
  28. }
  29. if (!$user) {
  30. return response()->error('QAPP_TOKEN_ERROR');
  31. }
  32. $this->events->fire('tymon.jwt.valid', $user);
  33. return $next($request);
  34. }
  35. }