mirror of
https://github.com/ZeroDream-CN/SakuraPanel.git
synced 2025-01-12 18:02:51 +08:00
224 lines
7.1 KiB
PHP
224 lines
7.1 KiB
PHP
|
<?php
|
||
|
error_reporting(0);
|
||
|
Header("Content-type: text/plain");
|
||
|
$conn = mysqli_connect(
|
||
|
/* 数据库地址 */ "localhost",
|
||
|
/* 数据库账号 */ "root",
|
||
|
/* 数据库密码 */ "123456",
|
||
|
/* 数据库名称 */ "spanel",
|
||
|
/* 数据库端口 */ 3306
|
||
|
) or die("Database error");
|
||
|
|
||
|
// API 密码,需要和 Frps.ini 里面设置的一样
|
||
|
define("API_TOKEN", "SakuraFrpToken");
|
||
|
|
||
|
// 输出禁止错误 Header
|
||
|
function ServerForbidden($msg) {
|
||
|
Header("HTTP/1.1 403 {$msg}");
|
||
|
echo json_encode(Array(
|
||
|
'status' => 403,
|
||
|
'message' => $msg
|
||
|
), JSON_UNESCAPED_UNICODE);
|
||
|
exit;
|
||
|
}
|
||
|
|
||
|
// 输出未找到错误 Header
|
||
|
function ServerNotFound($msg) {
|
||
|
Header("HTTP/1.1 404 {$msg}");
|
||
|
echo json_encode(Array(
|
||
|
'status' => 404,
|
||
|
'message' => $msg
|
||
|
), JSON_UNESCAPED_UNICODE);
|
||
|
exit;
|
||
|
}
|
||
|
|
||
|
// 输出未找到错误 Header
|
||
|
function ServerBadRequest($msg) {
|
||
|
Header("HTTP/1.1 400 {$msg}");
|
||
|
echo json_encode(Array(
|
||
|
'status' => 400,
|
||
|
'message' => $msg
|
||
|
), JSON_UNESCAPED_UNICODE);
|
||
|
exit;
|
||
|
}
|
||
|
|
||
|
// 输出正常消息
|
||
|
function LoginSuccessful($msg) {
|
||
|
Header("Content-type: text/plain", true, 200);
|
||
|
echo json_encode(Array(
|
||
|
'status' => 200,
|
||
|
'success' => true,
|
||
|
'message' => $msg
|
||
|
), JSON_UNESCAPED_UNICODE);
|
||
|
exit;
|
||
|
}
|
||
|
|
||
|
// 输出正常消息
|
||
|
function CheckSuccessful($msg) {
|
||
|
Header("Content-type: text/plain", true, 200);
|
||
|
echo json_encode(Array(
|
||
|
'status' => 200,
|
||
|
'success' => true,
|
||
|
'message' => $msg
|
||
|
), JSON_UNESCAPED_UNICODE);
|
||
|
exit;
|
||
|
}
|
||
|
|
||
|
// Json 格式消息输出
|
||
|
function Println($data) {
|
||
|
Header("Content-type: text/plain", true, 200);
|
||
|
echo json_encode($data, JSON_UNESCAPED_UNICODE);
|
||
|
exit;
|
||
|
}
|
||
|
|
||
|
function getBoolean($str) {
|
||
|
return $str == "true";
|
||
|
}
|
||
|
|
||
|
// 服务端 API 部分
|
||
|
// 先进行 Frps 鉴权
|
||
|
if(isset($_GET['apitoken']) && $_GET['apitoken'] == API_TOKEN) {
|
||
|
if(isset($_GET['action'])) {
|
||
|
switch($_GET['action']) {
|
||
|
|
||
|
// 检查客户端是否合法
|
||
|
case "checktoken":
|
||
|
if(isset($_GET['user'])) {
|
||
|
if(preg_match("/^[A-Za-z0-9]{1,32}$/", $_GET['user'])) {
|
||
|
$userToken = mysqli_real_escape_string($conn, $_GET['user']);
|
||
|
$rs = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `tokens` WHERE `token`='{$userToken}'"));
|
||
|
if($rs) {
|
||
|
LoginSuccessful("Login successful, welcome!");
|
||
|
} else {
|
||
|
ServerForbidden("Login failed");
|
||
|
}
|
||
|
} else {
|
||
|
ServerForbidden("Invalid username");
|
||
|
}
|
||
|
} else {
|
||
|
ServerForbidden("Username cannot be empty");
|
||
|
}
|
||
|
break;
|
||
|
|
||
|
// 检查隧道是否合法
|
||
|
case "checkproxy":
|
||
|
if(isset($_GET['user'])) {
|
||
|
if(preg_match("/^[A-Za-z0-9]{1,32}$/", $_GET['user'])) {
|
||
|
$proxyName = str_replace("{$_GET['user']}.", "", $_GET['proxy_name']);
|
||
|
$proxyType = $_GET['proxy_type'] ?? "tcp";
|
||
|
$remotePort = Intval($_GET['remote_port']) ?? "";
|
||
|
$userToken = mysqli_real_escape_string($conn, $_GET['user']);
|
||
|
$rs = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `tokens` WHERE `token`='{$userToken}'"));
|
||
|
if($rs) {
|
||
|
if($proxyType == "tcp" || $proxyType == "udp" || $proxyType == "stcp" || $proxyType == "xtcp") {
|
||
|
if(isset($remotePort) && preg_match("/^[0-9]{1,5}$/", $remotePort)) {
|
||
|
$username = mysqli_real_escape_string($conn, $rs['username']);
|
||
|
// 这里只对远程端口做限制,可根据自己的需要修改
|
||
|
$rs = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `proxies` WHERE `username`='{$username}' AND `remote_port`='{$remotePort}' AND `proxy_type`='{$proxyType}'"));
|
||
|
if($rs) {
|
||
|
if($rs['status'] !== "0") {
|
||
|
ServerForbidden("Proxy disabled");
|
||
|
}
|
||
|
CheckSuccessful("Proxy exist");
|
||
|
} else {
|
||
|
ServerNotFound("Proxy not found" . "SELECT * FROM `proxies` WHERE `username`='{$username}' AND `remote_port`='{$remotePort}' AND `proxy_type`='{$proxyType}'");
|
||
|
}
|
||
|
} else {
|
||
|
ServerBadRequest("Invalid request");
|
||
|
}
|
||
|
} elseif($proxyType == "http" || $proxyType == "https") {
|
||
|
if(isset($_GET['domain']) || isset($_GET['subdomain'])) {
|
||
|
// 目前只验证域名和子域名
|
||
|
$domain = $_GET['domain'] ?? "null";
|
||
|
$subdomain = $_GET['subdomain'] ?? "null";
|
||
|
$username = mysqli_real_escape_string($conn, $rs['username']);
|
||
|
$domain = mysqli_real_escape_string($conn, $domain);
|
||
|
$subdomain = mysqli_real_escape_string($conn, $subdomain);
|
||
|
$domainsql = (isset($_GET['domain']) && !empty($_GET['domain'])) ? "`domain`='{$domain}'" : "`subdomain`='{$subdomain}'";
|
||
|
$rs = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `proxies` WHERE `username`='{$username}' AND {$domainsql} AND `proxy_type`='{$proxyType}'"));
|
||
|
if($rs) {
|
||
|
if($rs['status'] !== "0") {
|
||
|
ServerForbidden("Proxy disabled");
|
||
|
}
|
||
|
CheckSuccessful("Proxy exist");
|
||
|
} else {
|
||
|
ServerNotFound("Proxy not found");
|
||
|
}
|
||
|
} else {
|
||
|
ServerBadRequest("Invalid request");
|
||
|
}
|
||
|
} else {
|
||
|
ServerBadRequest("Invalid request");
|
||
|
}
|
||
|
} else {
|
||
|
ServerNotFound("User not found");
|
||
|
}
|
||
|
} else {
|
||
|
ServerBadRequest("Invalid request");
|
||
|
}
|
||
|
} else {
|
||
|
ServerForbidden("Invalid username");
|
||
|
}
|
||
|
break;
|
||
|
case "getlimit":
|
||
|
Header("Content-type: text/plain", true, 200);
|
||
|
if(isset($_GET['user'])) {
|
||
|
if(preg_match("/^[A-Za-z0-9]{1,32}$/", $_GET['user'])) {
|
||
|
$userToken = mysqli_real_escape_string($conn, $_GET['user']);
|
||
|
$rs = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `tokens` WHERE `token`='{$userToken}'"));
|
||
|
if($rs) {
|
||
|
$username = mysqli_real_escape_string($conn, $rs['username']);
|
||
|
$ls = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `limits` WHERE `username`='{$username}'"));
|
||
|
if($ls) {
|
||
|
exit(json_encode(Array(
|
||
|
'status' => 200,
|
||
|
'max-in' => Floatval($ls['inbound']),
|
||
|
'max-out' => Floatval($ls['outbound'])
|
||
|
)));
|
||
|
} else {
|
||
|
$uinfo = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `users` WHERE `username`='{$username}'"));
|
||
|
if($uinfo) {
|
||
|
if($rs['group'] == "admin") {
|
||
|
exit(json_encode(Array(
|
||
|
'status' => 200,
|
||
|
'max-in' => 1000000,
|
||
|
'max-out' => 1000000
|
||
|
)));
|
||
|
}
|
||
|
$group = mysqli_real_escape_string($conn, $rs['group']);
|
||
|
$gs = mysqli_fetch_array(mysqli_query($conn, "SELECT * FROM `groups` WHERE `name`='{$group}'"));
|
||
|
if($gs) {
|
||
|
exit(json_encode(Array(
|
||
|
'status' => 200,
|
||
|
'max-in' => Floatval($gs['inbound']),
|
||
|
'max-out' => Floatval($gs['outbound'])
|
||
|
)));
|
||
|
} else {
|
||
|
exit(json_encode(Array(
|
||
|
'status' => 200,
|
||
|
'max-in' => 1024,
|
||
|
'max-out' => 1024
|
||
|
)));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
} else {
|
||
|
ServerForbidden("Login failed");
|
||
|
}
|
||
|
} else {
|
||
|
ServerForbidden("Invalid username");
|
||
|
}
|
||
|
} else {
|
||
|
ServerForbidden("Username cannot be empty");
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
ServerNotFound("Undefined action");
|
||
|
}
|
||
|
} else {
|
||
|
ServerNotFound("Invalid request");
|
||
|
}
|
||
|
} else {
|
||
|
ServerNotFound("Invalid request");
|
||
|
}
|