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 {
const { remark, port, protocol, streamSettings = "{}" } = inbound.obj || {}; network = "ws",
const { security = "none",
network = "ws", wsSettings: { host, path },
security = "none", } = JSON.parse(streamSettings);
wsSettings: { host, path }, ctx.body = {
} = JSON.parse(streamSettings); code: "0",
return ctx.body = { data: `${protocol}://${uuid}@vless.jjcp52.com:${port}?type=${network}&path=${path}&host=${host}&security=${security}#${remark}-${email}`,
code: "0", message: "success",
data: `${protocol}://${uuid}@vless.jjcp52.com:${port}?type=${network}&path=${path}&host=${host}&security=${security}#${remark}-${email}`, };
message: "success", } else {
}; ctx.body = {
} code: 1,
}) message: "添加失败",
.finally(() => { data: ctx.request.body,
ctx.body = { };
message: "Example POST API", }
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);