QuickAppGetUserFromToken.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Modules\Push\Services\PushService;
  4. use App\Modules\User\Services\QappUserService;
  5. use App\Modules\User\Services\UserService;
  6. use Closure;
  7. use Exception;
  8. use Illuminate\Http\Request;
  9. use Tymon\JWTAuth\Exceptions\JWTException;
  10. use Tymon\JWTAuth\Exceptions\TokenExpiredException;
  11. use Tymon\JWTAuth\Middleware\BaseMiddleware;
  12. class QuickAppGetUserFromToken extends BaseMiddleware
  13. {
  14. /**
  15. * Handle an incoming request.
  16. *
  17. * @param \Illuminate\Http\Request $request
  18. * @param \Closure $next
  19. * @return mixed
  20. */
  21. public function handle(Request $request, Closure $next)
  22. {
  23. $version = $request->header('X-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. UserService::setUserSendOrder($user->id, $send_order_id);
  32. }
  33. (new QappUserService)->setGolableUser($user->id);
  34. } catch (TokenExpiredException $e) {
  35. return response()->error('QAPP_TOKEN_ERROR');
  36. } catch (JWTException $e) {
  37. return response()->error('QAPP_TOKEN_ERROR');
  38. } catch (Exception $e) {
  39. return response()->error('QAPP_NOT_LOGIN');
  40. }
  41. // 更新用户reg_id
  42. $uid = $user->id;
  43. $package = $request->header('x-package', '');
  44. $provider = $request->header('x-provider', '');
  45. $regId = $request->header('x-regid', '');
  46. PushService::setUserRegId($uid, $regId, $provider, $package);
  47. return $next($request);
  48. }
  49. }