QuickAppGetUserFromToken.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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\Models\QappCallbackParams;
  8. use App\Modules\User\Services\QappUserService;
  9. use App\Modules\User\Services\UserService;
  10. use Closure;
  11. use Exception;
  12. use Illuminate\Http\Request;
  13. use Tymon\JWTAuth\Exceptions\JWTException;
  14. use Tymon\JWTAuth\Exceptions\TokenExpiredException;
  15. use Tymon\JWTAuth\Middleware\BaseMiddleware;
  16. class QuickAppGetUserFromToken extends BaseMiddleware
  17. {
  18. /**
  19. * Handle an incoming request.
  20. *
  21. * @param \Illuminate\Http\Request $request
  22. * @param \Closure $next
  23. * @return mixed
  24. */
  25. public function handle(Request $request, Closure $next)
  26. {
  27. // 获取头部信息
  28. $package = $request->header('x-package', '');
  29. $provider = $request->header('x-provider', '');
  30. $regId = $request->header('x-regid', '');
  31. $pushId = $request->header('x-pushid', 0);
  32. $sendOrderId = $request->header('send-order-id', 0);
  33. // 判断是否登录
  34. if (!$token = $this->auth->setRequest($request)->getToken()) {
  35. return response()->error('QAPP_NOT_LOGIN');
  36. }
  37. try {
  38. $user = $this->auth->authenticate($token);
  39. if (empty($user->id)) {
  40. return response()->error('QAPP_NOT_LOGIN');
  41. }
  42. if ($sendOrderId) {
  43. try {
  44. $result = SendOrderService::recordUserSendOrder($user->id, $sendOrderId);
  45. if($result){
  46. UserService::setUserSendOrder($user->id, $sendOrderId);
  47. }
  48. } catch (\Exception $e) {
  49. myLog('QuickAppGetUserFromToken-sendOrderId')->error($e);
  50. }
  51. }
  52. // 设置全局信息
  53. (new QappUserService)->setGolableUser($user->id, $package);
  54. } catch (TokenExpiredException $e) {
  55. return response()->error('QAPP_TOKEN_ERROR');
  56. } catch (JWTException $e) {
  57. return response()->error('QAPP_TOKEN_ERROR');
  58. } catch (Exception $e) {
  59. myLog('QuickAppGetUserFromToken')->info($e->getMessage());
  60. return response()->error('QAPP_NOT_LOGIN');
  61. }
  62. // 更新用户reg_id
  63. $uid = $user->id;
  64. PushService::setUserRegId($uid, $regId, $provider, $package);
  65. // 推送pv、uv统计
  66. if ($pushId) {
  67. PushCache::incrPushPv($pushId, date('Ymd'));
  68. PushCache::zAddPushUv($pushId, date('Ymd'), $uid);
  69. }
  70. // 头条次留回传
  71. ReportService::reportActive($uid);
  72. if(isset($request['tid']) && isset($request['pageId'])){
  73. $provider = strtolower($provider);
  74. if(!QappCallbackParams::where('uid',$uid)->where('provider',$provider)->first()){
  75. //获取oppo回传需要的参数
  76. $path = $request->path();
  77. $params = json_encode(['tid' => $request['tid'], 'pageId' => $request['pageId']]);
  78. QappCallbackParams::create(compact('uid','path','provider','params'));
  79. }
  80. }
  81. return $next($request);
  82. }
  83. }