WebApi.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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 Response::json([
  22. "status" => "fail",
  23. "code" => 404,
  24. "data" => "",
  25. "message" => "Your key is null"
  26. ]);
  27. }elseif($id === null){// 未提供 node
  28. return Response::json([
  29. "status" => "fail",
  30. "code" => 404,
  31. "data" => "",
  32. "message" => "Your Node Id is null"
  33. ]);
  34. }
  35. $node = SsNode::query()->whereId($id)->first();
  36. if(!$node){// node不存在
  37. return Response::json([
  38. "status" => "fail",
  39. "code" => 404,
  40. "data" => "",
  41. "message" => "Unknown Node"
  42. ]);
  43. }
  44. $nodeAuth = NodeAuth::query()->whereNodeId($id)->first();
  45. if(!$nodeAuth || $key != $nodeAuth->key){// key不存在/不匹配
  46. return Response::json([
  47. "status" => "fail",
  48. "code" => 404,
  49. "data" => "",
  50. "message" => "Token is invalid"
  51. ]);
  52. }
  53. if(abs($time - time()) >= 300){//时差超过5分钟
  54. return Response::json([
  55. "status" => "fail",
  56. "code" => 404,
  57. "data" => "",
  58. "message" => "Please resynchronize the server time!"
  59. ]);
  60. }
  61. return $next($request);
  62. }
  63. }