WebApi.php 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Models\NodeAuth;
  4. use App\Models\SsNode;
  5. use Closure;
  6. use Response;
  7. class WebApi {
  8. /**
  9. * Handle an incoming request.
  10. *
  11. * @param $request
  12. * @param Closure $next
  13. *
  14. * @return mixed
  15. */
  16. public function handle($request, Closure $next) {
  17. $id = $request->id;
  18. $key = $request->header('key');
  19. $time = $request->header('timestamp');
  20. if($key === null){// 未提供 key
  21. return $this->returnData('Your key is null!');
  22. }elseif($id === null){// 未提供 node
  23. return $this->returnData('Your Node Id is null!');
  24. }
  25. $node = SsNode::query()->whereId($id)->first();
  26. if(!$node){// node不存在
  27. return $this->returnData('Unknown Node!');
  28. }
  29. $nodeAuth = NodeAuth::query()->whereNodeId($id)->first();
  30. if(!$nodeAuth || $key != $nodeAuth->key){// key不存在/不匹配
  31. return $this->returnData('Token is invalid!');
  32. }
  33. if(abs($time - time()) >= 300){// 时差超过5分钟
  34. return $this->returnData('Please resynchronize the server time!');
  35. }
  36. return $next($request);
  37. }
  38. // 返回数据
  39. public function returnData($message) {
  40. return Response::json(['status' => 'fail', 'code' => 404, 'data' => '', 'message' => $message]);
  41. }
  42. }