WebApi.php 996 B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Helpers\ResponseEnum;
  4. use App\Helpers\WebApiResponse;
  5. use Closure;
  6. class WebApi
  7. {
  8. /**
  9. * Handle an incoming request.
  10. *
  11. * @param $request
  12. * @param Closure $next
  13. * @return mixed
  14. */
  15. use WebApiResponse;
  16. public function handle($request, Closure $next)
  17. {
  18. $node = $request->node;
  19. $key = $request->header('key');
  20. $time = $request->header('timestamp');
  21. if (! isset($key)) { // 未提供 key
  22. return $this->failed([400200, 'Your key is null!']);
  23. }
  24. $nodeAuth = $node->auth ?? null;
  25. if (! isset($nodeAuth) || $key !== $nodeAuth->key) { // key不存在/不匹配
  26. return $this->failed(ResponseEnum::CLIENT_PARAMETER_ERROR);
  27. }
  28. if (abs($time - time()) >= 300) { // 时差超过5分钟
  29. return $this->failed(ResponseEnum::CLIENT_HTTP_UNSYNCHRONIZE_TIMER);
  30. }
  31. return $next($request);
  32. }
  33. }