123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- <?php
- namespace App\Http\Middleware;
- use App\Models\Node;
- use App\Models\NodeAuth;
- use Closure;
- use Illuminate\Http\JsonResponse;
- use Response;
- class WebApi
- {
-
- public function handle($request, Closure $next)
- {
- $id = $request->id;
- $key = $request->header('key');
- $time = $request->header('timestamp');
- if (! isset($key)) {
- return $this->returnData('Your key is null!');
- }
- if (! isset($id)) {
- return $this->returnData('Your Node Id is null!');
- }
- $node = Node::find($id);
- if (! $node) {
- return $this->returnData('Unknown Node!');
- }
- $nodeAuth = NodeAuth::whereNodeId($id)->first();
- if (! $nodeAuth || $key !== $nodeAuth->key) {
- return $this->returnData('Token is invalid!');
- }
- if (abs($time - time()) >= 300) {
- return $this->returnData('Please resynchronize the server time!');
- }
- return $next($request);
- }
-
- public function returnData($message): JsonResponse
- {
- return Response::json(['status' => 'fail', 'code' => 404, 'message' => $message]);
- }
- }
|