update 2025-01-01 20:37:00

This commit is contained in:
kenzok8 2025-01-01 20:37:00 +08:00
parent e03e8f5b78
commit 5665025a5c
4 changed files with 38 additions and 17 deletions

View File

@ -978,7 +978,7 @@ window.onload = function() {
<h2 class="text-center">日志</h2> <h2 class="text-center">日志</h2>
<ul class="nav nav-pills mb-3" id="logTabs" role="tablist"> <ul class="nav nav-pills mb-3" id="logTabs" role="tablist">
<li class="nav-item" role="presentation"> <li class="nav-item" role="presentation">
<a class="nav-link active" id="pluginLogTab" data-bs-toggle="pill" href="#pluginLog" role="tab" aria-controls="pluginLog" aria-selected="true">NeKoBox 日志</a> <a class="nav-link" id="pluginLogTab" data-bs-toggle="pill" href="#pluginLog" role="tab" aria-controls="pluginLog" aria-selected="true">NeKoBox 日志</a>
</li> </li>
<li class="nav-item" role="presentation"> <li class="nav-item" role="presentation">
<a class="nav-link" id="mihomoLogTab" data-bs-toggle="pill" href="#mihomoLog" role="tab" aria-controls="mihomoLog" aria-selected="false">Mihomo 日志</a> <a class="nav-link" id="mihomoLogTab" data-bs-toggle="pill" href="#mihomoLog" role="tab" aria-controls="mihomoLog" aria-selected="false">Mihomo 日志</a>
@ -989,7 +989,7 @@ window.onload = function() {
</ul> </ul>
<div class="tab-content" id="logTabsContent"> <div class="tab-content" id="logTabsContent">
<div class="tab-pane fade show active" id="pluginLog" role="tabpanel" aria-labelledby="pluginLogTab"> <div class="tab-pane fade" id="pluginLog" role="tabpanel" aria-labelledby="pluginLogTab">
<div class="card log-card"> <div class="card log-card">
<div class="card-body"> <div class="card-body">
<pre id="plugin_log" class="log-container form-control" style="resize: vertical; overflow: auto; height: 350px; white-space: pre-wrap;" contenteditable="true"></pre> <pre id="plugin_log" class="log-container form-control" style="resize: vertical; overflow: auto; height: 350px; white-space: pre-wrap;" contenteditable="true"></pre>
@ -1148,6 +1148,22 @@ window.onload = function() {
}); });
</script> </script>
<script>
window.addEventListener('load', function() {
const activeTab = localStorage.getItem('activeTab') || 'pluginLogTab';
const activeTabLink = document.getElementById(activeTab);
const activeTabPane = document.getElementById(activeTab.replace('Tab', ''));
activeTabLink.classList.add('active');
activeTabPane.classList.add('show', 'active');
});
document.querySelectorAll('.nav-link').forEach(tab => {
tab.addEventListener('click', function() {
const selectedTab = this.id;
localStorage.setItem('activeTab', selectedTab);
});
});
</script>
</body> </body>
</html> </html>
<footer class="text-center"> <footer class="text-center">

View File

@ -829,10 +829,10 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
} }
queryParam.type = queryParam.type.toLowerCase(); queryParam.type = queryParam.type.toLowerCase();
if (queryParam.type === "kcp" || queryParam.type === "mkcp") { if (queryParam.type === "kcp") {
queryParam.type = "mkcp"; queryParam.type = "mkcp";
} }
if (queryParam.type === "h2" || queryParam.type === "http") { if (queryParam.type === "h2") {
queryParam.type = "http"; queryParam.type = "http";
} }
if (dom_prefix == "singbox_" && queryParam.type === "raw") { if (dom_prefix == "singbox_" && queryParam.type === "raw") {
@ -872,7 +872,7 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
opt.set(dom_prefix + 'ws_earlyDataHeaderName', 'Sec-WebSocket-Protocol'); opt.set(dom_prefix + 'ws_earlyDataHeaderName', 'Sec-WebSocket-Protocol');
} }
} }
} else if (queryParam.type === "h2" || queryParam.type === "http") { } else if (queryParam.type === "http") {
if (dom_prefix == "xray_") { if (dom_prefix == "xray_") {
opt.set(dom_prefix + 'xhttp_mode', "stream-one"); opt.set(dom_prefix + 'xhttp_mode', "stream-one");
opt.set(dom_prefix + 'xhttp_host', queryParam.host || ""); opt.set(dom_prefix + 'xhttp_host', queryParam.host || "");
@ -885,7 +885,7 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
opt.set(dom_prefix + 'quic_guise', queryParam.headerType || "none"); opt.set(dom_prefix + 'quic_guise', queryParam.headerType || "none");
opt.set(dom_prefix + 'quic_security', queryParam.quicSecurity); opt.set(dom_prefix + 'quic_security', queryParam.quicSecurity);
opt.set(dom_prefix + 'quic_key', queryParam.key); opt.set(dom_prefix + 'quic_key', queryParam.key);
} else if (queryParam.type === "kcp" || queryParam.type === "mkcp") { } else if (queryParam.type === "mkcp") {
opt.set(dom_prefix + 'mkcp_guise', queryParam.headerType || "none"); opt.set(dom_prefix + 'mkcp_guise', queryParam.headerType || "none");
} else if (queryParam.type === "grpc") { } else if (queryParam.type === "grpc") {
opt.set(dom_prefix + 'grpc_serviceName', (queryParam.serviceName || queryParam.path) || ""); opt.set(dom_prefix + 'grpc_serviceName', (queryParam.serviceName || queryParam.path) || "");
@ -961,10 +961,10 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
opt.set(dom_prefix + 'password', decodeURIComponent(password)); opt.set(dom_prefix + 'password', decodeURIComponent(password));
queryParam.type = queryParam.type ? queryParam.type.toLowerCase() : "tcp"; queryParam.type = queryParam.type ? queryParam.type.toLowerCase() : "tcp";
if (queryParam.type === "kcp" || queryParam.type === "mkcp") { if (queryParam.type === "kcp") {
queryParam.type = "mkcp"; queryParam.type = "mkcp";
} }
if (queryParam.type === "h2" || queryParam.type === "http") { if (queryParam.type === "h2") {
queryParam.type = "http"; queryParam.type = "http";
} }
if (dom_prefix == "singbox_" && queryParam.type === "raw") { if (dom_prefix == "singbox_" && queryParam.type === "raw") {
@ -1004,7 +1004,7 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
opt.set(dom_prefix + 'ws_earlyDataHeaderName', 'Sec-WebSocket-Protocol'); opt.set(dom_prefix + 'ws_earlyDataHeaderName', 'Sec-WebSocket-Protocol');
} }
} }
} else if (queryParam.type === "h2" || queryParam.type === "http") { } else if (queryParam.type === "http") {
if (dom_prefix == "xray_") { if (dom_prefix == "xray_") {
opt.set(dom_prefix + 'xhttp_mode', "stream-one"); opt.set(dom_prefix + 'xhttp_mode', "stream-one");
opt.set(dom_prefix + 'xhttp_host', queryParam.host || ""); opt.set(dom_prefix + 'xhttp_host', queryParam.host || "");
@ -1017,7 +1017,7 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
opt.set(dom_prefix + 'quic_guise', queryParam.headerType || "none"); opt.set(dom_prefix + 'quic_guise', queryParam.headerType || "none");
opt.set(dom_prefix + 'quic_security', queryParam.quicSecurity); opt.set(dom_prefix + 'quic_security', queryParam.quicSecurity);
opt.set(dom_prefix + 'quic_key', queryParam.key); opt.set(dom_prefix + 'quic_key', queryParam.key);
} else if (queryParam.type === "kcp" || queryParam.type === "mkcp") { } else if (queryParam.type === "mkcp") {
opt.set(dom_prefix + 'mkcp_guise', queryParam.headerType || "none"); opt.set(dom_prefix + 'mkcp_guise', queryParam.headerType || "none");
} else if (queryParam.type === "grpc") { } else if (queryParam.type === "grpc") {
opt.set(dom_prefix + 'grpc_serviceName', (queryParam.serviceName || queryParam.path) || ""); opt.set(dom_prefix + 'grpc_serviceName', (queryParam.serviceName || queryParam.path) || "");
@ -1198,12 +1198,15 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
} }
queryParam.type = queryParam.type.toLowerCase(); queryParam.type = queryParam.type.toLowerCase();
if (queryParam.type === "kcp" || queryParam.type === "mkcp") { if (queryParam.type === "kcp") {
queryParam.type = "mkcp"; queryParam.type = "mkcp";
} }
if (queryParam.type === "h2" || queryParam.type === "http") { if (queryParam.type === "h2") {
queryParam.type = "http"; queryParam.type = "http";
} }
if (queryParam.type === "splithttp") {
queryParam.type = "xhttp";
}
if (dom_prefix == "singbox_" && queryParam.type === "raw") { if (dom_prefix == "singbox_" && queryParam.type === "raw") {
queryParam.type = "tcp"; queryParam.type = "tcp";
} else if (dom_prefix == "xray_" && queryParam.type === "tcp") { } else if (dom_prefix == "xray_" && queryParam.type === "tcp") {
@ -1259,7 +1262,7 @@ local hysteria2_type = map:get("@global_subscribe[0]", "hysteria2_type") or "sin
} else if (queryParam.type === "grpc") { } else if (queryParam.type === "grpc") {
opt.set(dom_prefix + 'grpc_serviceName', (queryParam.serviceName || queryParam.path) || ""); opt.set(dom_prefix + 'grpc_serviceName', (queryParam.serviceName || queryParam.path) || "");
opt.set(dom_prefix + 'grpc_mode', queryParam.mode || "gun"); opt.set(dom_prefix + 'grpc_mode', queryParam.mode || "gun");
} else if (queryParam.type === "xhttp" || queryParam.type === "splithttp") { } else if (queryParam.type === "xhttp") {
opt.set(dom_prefix + 'xhttp_host', queryParam.host || ""); opt.set(dom_prefix + 'xhttp_host', queryParam.host || "");
opt.set(dom_prefix + 'xhttp_path', queryParam.path || ""); opt.set(dom_prefix + 'xhttp_path', queryParam.path || "");
opt.set(dom_prefix + 'xhttp_mode', queryParam.mode || "auto"); opt.set(dom_prefix + 'xhttp_mode', queryParam.mode || "auto");

View File

@ -465,6 +465,7 @@ local function processData(szType, content, add_mode, add_from)
elseif result.type == "Xray" and info.net == "tcp" then elseif result.type == "Xray" and info.net == "tcp" then
info.net = "raw" info.net = "raw"
end end
if info.net == "splithttp" then info.net = "xhttp" end
if info.net == 'h2' or info.net == 'http' then if info.net == 'h2' or info.net == 'http' then
info.net = "http" info.net = "http"
result.transport = (result.type == "Xray") and "xhttp" or "http" result.transport = (result.type == "Xray") and "xhttp" or "http"
@ -527,7 +528,7 @@ local function processData(szType, content, add_mode, add_from)
if info.net == 'grpc' then if info.net == 'grpc' then
result.grpc_serviceName = info.path result.grpc_serviceName = info.path
end end
if info.net == 'xhttp' or info.net == 'splithttp' then if info.net == 'xhttp' then
result.xhttp_host = info.host result.xhttp_host = info.host
result.xhttp_path = info.path result.xhttp_path = info.path
end end
@ -974,6 +975,7 @@ local function processData(szType, content, add_mode, add_from)
elseif result.type == "Xray" and params.type == "tcp" then elseif result.type == "Xray" and params.type == "tcp" then
params.type = "raw" params.type = "raw"
end end
if params.type == "splithttp" then params.type = "xhttp" end
if params.type == "h2" or params.type == "http" then if params.type == "h2" or params.type == "http" then
params.type = "http" params.type = "http"
result.transport = (result.type == "Xray") and "xhttp" or "http" result.transport = (result.type == "Xray") and "xhttp" or "http"
@ -1037,7 +1039,7 @@ local function processData(szType, content, add_mode, add_from)
if params.serviceName then result.grpc_serviceName = params.serviceName end if params.serviceName then result.grpc_serviceName = params.serviceName end
result.grpc_mode = params.mode or "gun" result.grpc_mode = params.mode or "gun"
end end
if params.type == 'xhttp' or params.type == 'splithttp' then if params.type == 'xhttp' then
result.xhttp_host = params.host result.xhttp_host = params.host
result.xhttp_path = params.path result.xhttp_path = params.path
result.xhttp_mode = params.mode or "auto" result.xhttp_mode = params.mode or "auto"

View File

@ -1,12 +1,12 @@
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
PKG_NAME:=xray-core PKG_NAME:=xray-core
PKG_VERSION:=24.12.18 PKG_VERSION:=24.12.31
PKG_RELEASE:=1 PKG_RELEASE:=1
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
PKG_SOURCE_URL:=https://codeload.github.com/XTLS/Xray-core/tar.gz/v$(PKG_VERSION)? PKG_SOURCE_URL:=https://codeload.github.com/XTLS/Xray-core/tar.gz/v$(PKG_VERSION)?
PKG_HASH:=3d8b4a161a263e7af7bb1a2690961da075d13f980acd806f5cd4e5c8338d7534 PKG_HASH:=e3c24b561ab422785ee8b7d4a15e44db159d9aa249eb29a36ad1519c15267be0
PKG_MAINTAINER:=Tianling Shen <cnsztl@immortalwrt.org> PKG_MAINTAINER:=Tianling Shen <cnsztl@immortalwrt.org>
PKG_LICENSE:=MPL-2.0 PKG_LICENSE:=MPL-2.0