QuickAppGetUserFromToken.php 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Cache\Push\PushCache;
  4. use App\Modules\Push\Services\PushService;
  5. use App\Modules\Report\Services\ReportService;
  6. use App\Modules\SendOrder\Services\SendOrderService;
  7. use App\Modules\User\Services\QappUserService;
  8. use App\Modules\User\Services\UserService;
  9. use Closure;
  10. use Exception;
  11. use Illuminate\Http\Request;
  12. use Tymon\JWTAuth\Exceptions\JWTException;
  13. use Tymon\JWTAuth\Exceptions\TokenExpiredException;
  14. use Tymon\JWTAuth\Middleware\BaseMiddleware;
  15. class QuickAppGetUserFromToken extends BaseMiddleware
  16. {
  17. /**
  18. * Handle an incoming request.
  19. *
  20. * @param \Illuminate\Http\Request $request
  21. * @param \Closure $next
  22. * @return mixed
  23. */
  24. public function handle(Request $request, Closure $next)
  25. {
  26. // 获取头部信息
  27. $package = $request->header('x-package', '');
  28. $provider = $request->header('x-provider', '');
  29. $regId = $request->header('x-regid', '');
  30. $pushId = $request->header('x-pushid', 0);
  31. $sendOrderId = $request->header('send-order-id', 0);
  32. // 判断是否登录
  33. if (!$token = $this->auth->setRequest($request)->getToken()) {
  34. return response()->error('QAPP_NOT_LOGIN');
  35. }
  36. try {
  37. $user = $this->auth->authenticate($token);
  38. if (empty($user->id)) {
  39. return response()->error('QAPP_NOT_LOGIN');
  40. }
  41. if ($sendOrderId) {
  42. try {
  43. $result = SendOrderService::recordUserSendOrder($user->id, $sendOrderId);
  44. if($result){
  45. UserService::setUserSendOrder($user->id, $sendOrderId);
  46. }
  47. } catch (\Exception $e) {
  48. myLog('QuickAppGetUserFromToken-sendOrderId')->error($e);
  49. }
  50. }
  51. // 设置全局信息
  52. (new QappUserService)->setGolableUser($user->id, $package);
  53. } catch (TokenExpiredException $e) {
  54. return response()->error('QAPP_TOKEN_ERROR');
  55. } catch (JWTException $e) {
  56. return response()->error('QAPP_TOKEN_ERROR');
  57. } catch (Exception $e) {
  58. myLog('QuickAppGetUserFromToken')->info($e->getMessage());
  59. return response()->error('QAPP_NOT_LOGIN');
  60. }
  61. // 更新用户reg_id
  62. $uid = $user->id;
  63. PushService::setUserRegId($uid, $regId, $provider, $package);
  64. // 推送pv、uv统计
  65. if ($pushId) {
  66. PushCache::incrPushPv($pushId, date('Ymd'));
  67. PushCache::zAddPushUv($pushId, date('Ymd'), $uid);
  68. }
  69. // 头条次留回传
  70. ReportService::reportActive($uid);
  71. return $next($request);
  72. }
  73. }