feat(api): 优化客户端添加功能
- 添加用户认证和 Cookie 设置 - 重构 API 请求逻辑,提高可维护性 - 优化错误处理和响应结构 - 调整实例配置和响应拦截器
This commit is contained in:
@@ -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,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
Reference in New Issue
Block a user