QuickAppGetUserFromToken.php 1.3 KB

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