QuickAppGetUserFromToken.php 3.7 KB

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