Files
ProxyPanel/app/Http/Middleware/WebApi.php
兔姬桑 ce9618236f 2.5.a 管理路由全面改写 与 代码拆分
1. 全面改写项目-管理面板的路由;
2. 拆分过于Contoller;
3. 优化了按钮过多的图表的显示;
4. 初步应用 Laravel的 表单验证功能;
5. 初步应用 Laravel的 component 功能 拆分/模块化前端代码;
6. 优化部分系统的判断逻辑;
7. 针对2.4.0以前的面板,追加辅助矫正数据库的sql文件;
2020-10-01 12:34:19 +08:00

58 lines
1.4 KiB
PHP

<?php
namespace App\Http\Middleware;
use App\Models\Node;
use App\Models\NodeAuth;
use Closure;
use Illuminate\Http\JsonResponse;
use Response;
class WebApi
{
/**
* Handle an incoming request.
*
* @param $request
* @param Closure $next
*
* @return mixed
*/
public function handle($request, Closure $next)
{
$id = $request->id;
$key = $request->header('key');
$time = $request->header('timestamp');
if (!isset($key)) {// 未提供 key
return $this->returnData('Your key is null!');
}
if (!isset($id)) {// 未提供 node
return $this->returnData('Your Node Id is null!');
}
$node = Node::find($id);
if (!$node) {// node不存在
return $this->returnData('Unknown Node!');
}
$nodeAuth = NodeAuth::whereNodeId($id)->first();
if (!$nodeAuth || $key !== $nodeAuth->key) {// key不存在/不匹配
return $this->returnData('Token is invalid!');
}
if (abs($time - time()) >= 300) {// 时差超过5分钟
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]);
}
}