QuickAppGetUserFromToken.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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. myLog('QuickAppGetUserFromToken')->info($e->getMessage());
  40. return response()->error('QAPP_NOT_LOGIN');
  41. }
  42. // 更新用户reg_id
  43. $uid = $user->id;
  44. $package = $request->header('x-package', '');
  45. $provider = $request->header('x-provider', '');
  46. $regId = $request->header('x-regid', '');
  47. PushService::setUserRegId($uid, $regId, $provider, $package);
  48. return $next($request);
  49. }
  50. }