feat(api): 优化客户端添加功能

- 添加用户认证和 Cookie 设置
- 重构 API 请求逻辑,提高可维护性
- 优化错误处理和响应结构
- 调整实例配置和响应拦截器
This commit is contained in:
aixianling
2025-02-26 15:50:30 +08:00
parent f4057ae956
commit c9a2cad670
2 changed files with 35 additions and 28 deletions

View File

@@ -1,36 +1,42 @@
const { randomUUID } = require("crypto"); const { randomUUID } = require("crypto");
const http = require("../../utils/http"); const ins = require("../../utils/http");
const dayjs = require("dayjs"); const dayjs = require("dayjs");
const getCookie = require("../../auth/3xuiLogin");
const { log } = require("console");
module.exports = async (ctx) => { module.exports = async (ctx) => {
let { id = 4, limitIp, expiryTime, enable = !0, totalGB = 1, subId = "2rv0gb458kbfl532" } = ctx.request.body; let { id = 4, limitIp, expiryTime, enable = !0, totalGB = 1, subId = "2rv0gb458kbfl532" } = ctx.request.body;
const inbound = await http.get(`/api/inbounds/get/${id}`); if (!ctx.state.cookie) {
ctx.state.cookie = await getCookie();
ins.interceptors.request.use((config) => {
config.headers.Cookie = ctx.state.cookie;
return config;
});
}
const inbound = await ins.get(`/panel/api/inbounds/get/${id}`);
if (!inbound?.success) return (ctx.body = { code: "1", msg: "获取节点失败" }); if (!inbound?.success) return (ctx.body = { code: "1", msg: "获取节点失败" });
const uuid = randomUUID(), const uuid = randomUUID(),
email = uuid.split("-")[0]; email = uuid.split("-")[0];
expiryTime = dayjs(expiryTime, "YYYY-MM-DD HH:mm:ss").valueOf(); expiryTime = dayjs(expiryTime, "YYYY-MM-DD HH:mm:ss").valueOf();
const settings = { clients: [{ id: uuid, flow: "", email, limitIp, enable, tgId: "", subId, reset: 0, totalGB, expiryTime }] }; const settings = { clients: [{ id: uuid, flow: "", email, limitIp, enable, tgId: "", subId, reset: 0, totalGB, expiryTime }] };
http const result = await ins.post("/panel/api/inbounds/addClient", { id, settings: JSON.stringify(settings) });
.post("/api/inbounds/addClient", { id, settings: JSON.stringify(settings) }) if (result?.success) {
.then((res) => { const { remark, port, protocol, streamSettings = "{}" } = inbound.data?.obj || {};
if (res?.success) {
const { remark, port, protocol, streamSettings = "{}" } = inbound.obj || {};
const { const {
network = "ws", network = "ws",
security = "none", security = "none",
wsSettings: { host, path }, wsSettings: { host, path },
} = JSON.parse(streamSettings); } = JSON.parse(streamSettings);
return ctx.body = { ctx.body = {
code: "0", code: "0",
data: `${protocol}://${uuid}@vless.jjcp52.com:${port}?type=${network}&path=${path}&host=${host}&security=${security}#${remark}-${email}`, data: `${protocol}://${uuid}@vless.jjcp52.com:${port}?type=${network}&path=${path}&host=${host}&security=${security}#${remark}-${email}`,
message: "success", message: "success",
}; };
} } else {
})
.finally(() => {
ctx.body = { ctx.body = {
message: "Example POST API", code: 1,
message: "添加失败",
data: ctx.request.body, data: ctx.request.body,
}; };
}); }
}; };

View File

@@ -3,9 +3,10 @@ const { default: axios } = require("axios");
const instance = axios.create({ baseURL: process.env.BASE_URL }); const instance = axios.create({ baseURL: process.env.BASE_URL });
instance.interceptors.response.use( instance.interceptors.response.use(
(response) => { (response) => {
if (response.data.code === 200) { if (response.status === 200 && !["/login"].includes(response.config.url)) {
return response.data.data; return response.data;
} else return response; }
return response;
}, },
(error) => { (error) => {
console.log(error); console.log(error);