QuickAppGetUserFromToken.php 1.6 KB

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