mirror of
https://github.com/KOP-XIAO/QuantumultX.git
synced 2026-01-25 17:15:09 +00:00
添加udp/tfo参数,添加emoji增减参数
This commit is contained in:
@@ -1,10 +1,22 @@
|
|||||||
/**
|
/**
|
||||||
* 2020-04-24:14:42 #tag
|
|
||||||
* 本资源解析器作者: Shawn (@XIAO_KOP) , 有问题请反馈:@Shawn_KOP_bot
|
#Quantumult X 节点资源解析器
|
||||||
* 功能: 将不同格式订阅转换成 Quantumult X,并支持简单的过滤.
|
|
||||||
* 目前支持 V2RayN/SSR/Trojan/Quanx 格式写法的节点引用;
|
本资源解析器作者: Shawn (@XIAO_KOP) , 有问题请反馈:@Shawn_KOP_bot
|
||||||
* 过滤参数为 in,out, 分别为保留与排除,多个参数间用+号连接, 可直接使用中文(如 in=香港+台湾)
|
|
||||||
* 示范,
|
#tag 2020-04-25: 11:50
|
||||||
|
|
||||||
|
功能:将不同格式订阅转换成 Quantumult X,并支持简单的节点过滤/emoji添加删除,udp/tfo 的开启.
|
||||||
|
- 目前支持 V2RayN/SSR/Trojan/Quanx 格式写法的节点引用;
|
||||||
|
|
||||||
|
1⃣️ 过滤参数为 in,out, 分别为保留与排除,多个参数间用+号连接, 可直接使用中文(如 in=香港+台湾)
|
||||||
|
2⃣️ emoji 参数为 emoji=1,2 或-1,为添加或删除节点名中的emoji旗帜(国行设备请用 emoji=2)
|
||||||
|
3⃣️ udp=1,tfo=1 参数开启 udp-relay 及fast-open
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 使用,
|
||||||
0⃣️ 在quantumult X 配置文件中[general] 部分,加入 resource_parser_url=https://raw.githubusercontent.com/KOP-XIAO/QuantumultX/master/Scripts/resource-parser.js
|
0⃣️ 在quantumult X 配置文件中[general] 部分,加入 resource_parser_url=https://raw.githubusercontent.com/KOP-XIAO/QuantumultX/master/Scripts/resource-parser.js
|
||||||
1⃣️ 原始订阅连接为: https://raw.githubusercontent.com/crossutility/Quantumult-X/master/server-complete.txt ,
|
1⃣️ 原始订阅连接为: https://raw.githubusercontent.com/crossutility/Quantumult-X/master/server-complete.txt ,
|
||||||
2⃣️ 想要保留的参数为 in=tls+ss, 想要过滤的参数为 out=http+2, 请注意下面订阅链接后一定要加 ”#“ 符号
|
2⃣️ 想要保留的参数为 in=tls+ss, 想要过滤的参数为 out=http+2, 请注意下面订阅链接后一定要加 ”#“ 符号
|
||||||
@@ -15,36 +27,44 @@
|
|||||||
var content0=$resource.content;
|
var content0=$resource.content;
|
||||||
var para=decodeURIComponent($resource.link);
|
var para=decodeURIComponent($resource.link);
|
||||||
var type0=Type_Check(content0);
|
var type0=Type_Check(content0);
|
||||||
|
var Pin0=para.indexOf("in=")!=-1? para.split("#")[1].split("in=")[1].split("&")[0].split("+"):null;
|
||||||
|
var Pout0=para.indexOf("out=")!=-1? para.split("#")[1].split("out=")[1].split("&")[0].split("+"):null;
|
||||||
|
var Pemoji=para.indexOf("emoji=")!=-1? para.split("#")[1].split("emoji=")[1].split("&")[0].split("+"):null;
|
||||||
|
var Pudp0=para.indexOf("udp=")!=-1? para.split("#")[1].split("udp=")[1].split("&")[0].split("+"):0;
|
||||||
|
var Ptfo0=para.indexOf("tfo=")!=-1? para.split("#")[1].split("tfo=")[1].split("&")[0].split("+"):0;
|
||||||
|
|
||||||
|
qx=["trojan=13.235.70.75:8443, password=8cacb13816.wns.windows.com, over-tls=true, tls-verification=false, tag=印度 AWS",
|
||||||
|
"trojan=47.105.52.185:458, password=8cacb13816.wns.windows.com, over-tls=true, tls-verification=false, tag=😀上海 BGP"]
|
||||||
|
|
||||||
if(type0=="Vmess"){
|
if(type0=="Vmess"){
|
||||||
total=V2QX(content0);
|
total=V2QX(content0,Pudp0,Ptfo0);
|
||||||
flag=1;
|
flag=1;
|
||||||
}else if(type0=="QuanX"){
|
}else if(type0=="QuanX"){
|
||||||
total=content0.split("\n");
|
total=content0.split("\n");
|
||||||
flag=1;
|
flag=1;
|
||||||
}else if(type0=="SSR"){
|
}else if(type0=="SSR"){
|
||||||
total=SSR2QX(content0);
|
total=SSR2QX(content0,Pudp0,Ptfo0);
|
||||||
flag=1;
|
flag=1;
|
||||||
}else if(type0=="Trojan"){
|
}else if(type0=="Trojan"){
|
||||||
total=TJ2QX(content0);
|
total=TJ2QX(content0,Pudp0,Ptfo0);
|
||||||
flag=1;
|
flag=1;
|
||||||
}else{
|
}else{
|
||||||
$notify("👻该解析器暂未支持您的订阅格式");
|
$notify("👻该解析器暂未支持您的订阅格式","😭太难写了", "stay tuned");
|
||||||
flag=0;
|
flag=0;
|
||||||
$done({content : content0});
|
$done({content : content0});
|
||||||
}
|
}
|
||||||
|
|
||||||
if(flag==1){
|
if(flag==1){
|
||||||
$notify("🤖 您订阅类型为:"+type0,"☠️ 您的订阅连接为: 其中#后面的为自定义传入参数","👉"+ para);
|
|
||||||
var Pin0=para.indexOf("in=")!=-1? para.split("#")[1].split("in=")[1].split("&")[0].split("+"):null;
|
|
||||||
var Pout0=para.indexOf("out=")!=-1? para.split("#")[1].split("out=")[1].split("&")[0].split("+"):null;
|
|
||||||
if(Pin0||Pout0){
|
if(Pin0||Pout0){
|
||||||
$notify("👥 开始转换并过滤节点","🐶 具体参数如下","👍️ 保留的关键字:"+Pin0+"\n👎️ 排除的关键字:"+Pout0);
|
$notify("👥 开始转换节点,类型:"+type0,"🐶 您已添加节点筛选参数,如下","👍️ 保留的关键字:"+Pin0+"\n👎️ 排除的关键字:"+Pout0);
|
||||||
total=filter(total,Pin0,Pout0)
|
total=filter(total,Pin0,Pout0)
|
||||||
} else {
|
} else {
|
||||||
$notify("🐷 未开启过滤节点","🐼️ 如需过滤节点请使用in/out参数,具体操作参考此示范:","👉 https://t.me/QuanXNews/110");
|
$notify("🐷 开始转换节点,类型:"+type0,"🐼️ 如需筛选节点请使用in/out及其他参数,可参考此示范:","👉 https://t.me/QuanXNews/110");
|
||||||
|
}
|
||||||
|
if(Pemoji){
|
||||||
|
$notify("🏳️🌈 开始更改旗帜 emoji","清除emoji请用参数 -1, 国行设备添加emoji请使用参数 2","你当前所用的参数为 emoji="+Pemoji);
|
||||||
|
total=emoji_handle(total,Pemoji);
|
||||||
}
|
}
|
||||||
//console.log(total)
|
|
||||||
$done({content : total.join("\n")});
|
$done({content : total.join("\n")});
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -65,12 +85,12 @@ function Type_Check(subs){
|
|||||||
}
|
}
|
||||||
|
|
||||||
//V2RayN 订阅转换成 QUANX 格式
|
//V2RayN 订阅转换成 QUANX 格式
|
||||||
function V2QX(subs){
|
function V2QX(subs,Pudp,Ptfo){
|
||||||
const $base64 = new Base64()
|
const $base64 = new Base64()
|
||||||
var list0=$base64.decode(subs).split("\n");
|
var list0=$base64.decode(subs).split("\n");
|
||||||
var QXList=[]
|
var QXList=[]
|
||||||
for(i in list0){
|
for(var i=0;i<list0.length; i++){
|
||||||
if(list0[i].trim()!=""){
|
if(list0[i].trim()!=""){
|
||||||
var server=String($base64.decode(list0[i].replace("vmess://","")).trim()).split("\u0000")[0];
|
var server=String($base64.decode(list0[i].replace("vmess://","")).trim()).split("\u0000")[0];
|
||||||
var nss=[];
|
var nss=[];
|
||||||
if(server!=""){
|
if(server!=""){
|
||||||
@@ -79,8 +99,8 @@ if(list0[i].trim()!=""){
|
|||||||
pwd="password="+ss.id;
|
pwd="password="+ss.id;
|
||||||
mtd="method=aes-128-gcm"
|
mtd="method=aes-128-gcm"
|
||||||
tag="tag="+decodeURIComponent(ss.ps);
|
tag="tag="+decodeURIComponent(ss.ps);
|
||||||
tfo="fast-open=false";
|
udp= Pudp==1? "udp-relay=true":"udp-relay=false";
|
||||||
udp="udp-relay=false";
|
tfo= Ptfo==1? "fast-open=true":"fast-open=false";
|
||||||
obfs=Pobfs(ss);
|
obfs=Pobfs(ss);
|
||||||
if(obfs==""){
|
if(obfs==""){
|
||||||
nss.push(ip,mtd,pwd,tfo,udp,tag)
|
nss.push(ip,mtd,pwd,tfo,udp,tag)
|
||||||
@@ -98,7 +118,7 @@ if(list0[i].trim()!=""){
|
|||||||
//节点过滤,使用+连接多个关键词:in 为保留,out 为排除
|
//节点过滤,使用+连接多个关键词:in 为保留,out 为排除
|
||||||
function filter(Servers,Pin,Pout){
|
function filter(Servers,Pin,Pout){
|
||||||
var NList=[];
|
var NList=[];
|
||||||
for(i in Servers){
|
for(var i=0;i<Servers.length; i++){
|
||||||
if(Servers[i].indexOf("tag")!=-1){
|
if(Servers[i].indexOf("tag")!=-1){
|
||||||
name=Servers[i].split("tag=")[1]
|
name=Servers[i].split("tag=")[1]
|
||||||
const include = (item) => name.indexOf(item) != -1;
|
const include = (item) => name.indexOf(item) != -1;
|
||||||
@@ -143,11 +163,11 @@ function Pobfs(jsonl){
|
|||||||
}
|
}
|
||||||
|
|
||||||
//SSR 转换 quanx 格式
|
//SSR 转换 quanx 格式
|
||||||
function SSR2QX(subs){
|
function SSR2QX(subs,Pudp,Ptfo){
|
||||||
const $base64 = new Base64()
|
const $base64 = new Base64()
|
||||||
var list0=$base64.decode(subs).split("\n");
|
var list0=$base64.decode(subs).split("\n");
|
||||||
var QXList=[];
|
var QXList=[];
|
||||||
for(i in list0){
|
for(var i=0;i<list0.length; i++){
|
||||||
if(list0[i].indexOf("ssr://")!=-1){
|
if(list0[i].indexOf("ssr://")!=-1){
|
||||||
var nssr=[]
|
var nssr=[]
|
||||||
var cnt=$base64.decode(list0[i].split("ssr://")[1].replace(/-/g,"+").replace(/_/g,"/"))
|
var cnt=$base64.decode(list0[i].split("ssr://")[1].replace(/-/g,"+").replace(/_/g,"/"))
|
||||||
@@ -165,8 +185,10 @@ function SSR2QX(subs){
|
|||||||
oparam=cnt.split("protoparam=")[1].split("&")[0]!=""? "ssr-protocol-param="+$base64.decode(cnt.split("protoparam=")[1].split("&")[0].replace(/-/g,"+").replace(/_/g,"/")).split(",")[0].split("\u0000")[0]+", ":""
|
oparam=cnt.split("protoparam=")[1].split("&")[0]!=""? "ssr-protocol-param="+$base64.decode(cnt.split("protoparam=")[1].split("&")[0].replace(/-/g,"+").replace(/_/g,"/")).split(",")[0].split("\u0000")[0]+", ":""
|
||||||
}
|
}
|
||||||
tag="tag="+($base64.decode(cnt.split("remarks=")[1].split("&")[0].replace(/-/g,"+").replace(/_/g,"/"))).split("\u0000")[0]
|
tag="tag="+($base64.decode(cnt.split("remarks=")[1].split("&")[0].replace(/-/g,"+").replace(/_/g,"/"))).split("\u0000")[0]
|
||||||
console.log($base64.decode(cnt.split("remarks=")[1].split("&")[0].replace(/-/g,"+").replace(/_/g,"/")))
|
//console.log($base64.decode(cnt.split("remarks=")[1].split("&")[0].replace(/-/g,"+").replace(/_/g,"/")))
|
||||||
nssr.push(type+ip,pwd,mtd,obfs+obfshost+oparam+ssrp,tag)
|
pudp= Pudp==1? "udp-relay=true":"udp-relay=false";
|
||||||
|
ptfo= Ptfo==1? "fast-open=true":"fast-open=false";
|
||||||
|
nssr.push(type+ip,pwd,mtd,obfs+obfshost+oparam+ssrp,pudp,ptfo,tag)
|
||||||
QX=nssr.join(", ")
|
QX=nssr.join(", ")
|
||||||
QXList.push(QX);
|
QXList.push(QX);
|
||||||
}
|
}
|
||||||
@@ -175,11 +197,11 @@ function SSR2QX(subs){
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Trojan 类型转换成 QX
|
//Trojan 类型转换成 QX
|
||||||
function TJ2QX(subs){
|
function TJ2QX(subs,Pudp,Ptfo){
|
||||||
const $base64 = new Base64()
|
const $base64 = new Base64()
|
||||||
var list0=$base64.decode(subs).split("\n");
|
var list0=$base64.decode(subs).split("\n");
|
||||||
var QXList=[];
|
var QXList=[];
|
||||||
for(i in list0){
|
for(var i=0;i<list0.length; i++){
|
||||||
if(list0[i].indexOf("trojan://")!=-1){
|
if(list0[i].indexOf("trojan://")!=-1){
|
||||||
var ntrojan=[]
|
var ntrojan=[]
|
||||||
var cnt=list0[i].split("trojan://")[1]
|
var cnt=list0[i].split("trojan://")[1]
|
||||||
@@ -188,8 +210,10 @@ function TJ2QX(subs){
|
|||||||
pwd="password="+cnt.split("@")[0];
|
pwd="password="+cnt.split("@")[0];
|
||||||
obfs="over-tls=true";
|
obfs="over-tls=true";
|
||||||
pcert= cnt.indexOf("allowInsecure=0")!= -1? "tls-verification=true":"tls-verification=false";
|
pcert= cnt.indexOf("allowInsecure=0")!= -1? "tls-verification=true":"tls-verification=false";
|
||||||
|
pudp= Pudp==1? "udp-relay=true":"udp-relay=false";
|
||||||
|
ptfo= Ptfo==1? "fast-open=true":"fast-open=false";
|
||||||
tag="tag="+decodeURIComponent(cnt.split("#")[1])
|
tag="tag="+decodeURIComponent(cnt.split("#")[1])
|
||||||
ntrojan.push(type+ip,pwd,obfs,pcert,tag)
|
ntrojan.push(type+ip,pwd,obfs,pcert,pudp,ptfo,tag)
|
||||||
QX=ntrojan.join(", ");
|
QX=ntrojan.join(", ");
|
||||||
QXList.push(QX);
|
QXList.push(QX);
|
||||||
}
|
}
|
||||||
@@ -198,6 +222,53 @@ function TJ2QX(subs){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//删除 emoji
|
||||||
|
function emoji_del(str) {
|
||||||
|
return unescape(escape(str).replace(/\%uD.{3}/g, ''));
|
||||||
|
}
|
||||||
|
|
||||||
|
//为节点名添加 emoji
|
||||||
|
function get_emoji(source,sname){
|
||||||
|
var cnt=source;
|
||||||
|
var flag=0;
|
||||||
|
for(var key in cnt){
|
||||||
|
dd=cnt[key]
|
||||||
|
for(i in dd){
|
||||||
|
if(sname.indexOf(dd[i])!=-1){
|
||||||
|
flag=1
|
||||||
|
nname=key+" "+sname;
|
||||||
|
return nname
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(flag==0){return "🏴☠️ "+sname}
|
||||||
|
}
|
||||||
|
|
||||||
|
//emoji 处理
|
||||||
|
function emoji_handle(servers,Pemoji){
|
||||||
|
var nlist=[]
|
||||||
|
var ser0=servers
|
||||||
|
for(var i=0;i<ser0.length; i++){
|
||||||
|
var oname=ser0[i].split("tag=")[1];
|
||||||
|
var hd=ser0[i].split("tag=")[0];
|
||||||
|
var nname=emoji_del(oname);
|
||||||
|
var Lmoji={"🏳️🌈": ["流量","时间","应急","过期","Bandwidth","expire"],"🇦🇨": ["AC"],"🇦🇷": ["AR","阿根廷"],"🇦🇹": ["奥地利","维也纳"],"🇦🇺": ["AU","Australia","Sydney","澳大利亚","澳洲","墨尔本","悉尼"],"🇧🇪": ["BE","比利时"],"🇧🇬️": ["保加利亚"],"🇧🇷": ["BR","Brazil","巴西","圣保罗"],"🇨🇦": ["Canada","Waterloo","加拿大","蒙特利尔","温哥华","楓葉","枫叶","滑铁卢","多伦多"],"🇨🇭": ["瑞士","苏黎世"],"🇩🇪": ["DE","German","GERMAN","德国","法兰克福","德"],"🇩🇰": ["丹麦"],"🇪🇸": ["ES"],"🇪🇺": ["EU"],"🇫🇮": ["Finland","芬兰","赫尔辛基"],"🇫🇷": ["FR","France","法国","法國","巴黎"],"🇬🇧": ["UK","England","United Kingdom","英国","伦敦","英"],"🇲🇴": ["MO","Macao","澳门","CTM"],"🇭🇰": ["HK","Hongkong","Hong Kong","香港","深港","沪港","呼港","HKT","HKBN","HGC","WTT","CMI","穗港","京港","港"],"🇮🇩": ["Indonesia","印尼","印度尼西亚","雅加达"],"🇮🇪": ["Ireland","爱尔兰","都柏林"],"🇮🇳": ["IN","India","印度","孟买","Mumbai"],"🇮🇹": ["Italy","Nachash","意大利","米兰","義大利"],"🇯🇵": ["JP","Japan","日本","东京","大阪","埼玉","沪日","穗日","川日","中日","泉日","杭日","深日","辽日"],"🇰🇵": ["KP","朝鲜"],"🇰🇷": ["KR","Korea","KOR","韩国","首尔","韩","韓"],"🇲🇽️": ["MEX","MX","墨西哥"],"🇲🇾": ["MY","Malaysia","马来西亚","吉隆坡"],"🇳🇱": ["NL","Netherlands","荷兰","荷蘭","尼德蘭","阿姆斯特丹"],"🇵🇭": ["PH","Philippines","菲律宾"],"🇷🇴": ["RO","罗马尼亚"],"🇷🇺": ["RU","Russia","俄罗斯","俄羅斯","伯力","莫斯科","圣彼得堡","西伯利亚","新西伯利亚","京俄","杭俄"],"🇸🇦": ["沙特","迪拜"],"🇸🇪": ["SE","Sweden"],"🇸🇬": ["SG","Singapore","新加坡","狮城","沪新","京新","泉新","穗新","深新","杭新"],"🇹🇭": ["TH","Thailand","泰国","泰國","曼谷"],"🇹🇷": ["TR","Turkey","土耳其","伊斯坦布尔"],"🇹🇼": ["TW","Taiwan","台湾","台北","台中","新北","彰化","CHT","台","HINET"],"🇺🇸": ["US","America","United States","美国","美","京美","波特兰","达拉斯","俄勒冈","凤凰城","费利蒙","硅谷","拉斯维加斯","洛杉矶","圣何塞","圣克拉拉","西雅图","芝加哥","沪美","哥伦布","纽约"],"🇻🇳": ["VN","越南","胡志明市"],"🇨🇳": ["CN","China","回国","中国","江苏","北京","上海","广州","深圳","杭州","徐州","青岛","宁波","镇江","back" ]}
|
||||||
|
if(Pemoji==1) {
|
||||||
|
str1 = JSON.stringify(Lmoji)
|
||||||
|
aa=JSON.parse(str1)
|
||||||
|
var nname=get_emoji(aa,nname)
|
||||||
|
} else if(Pemoji==2){
|
||||||
|
str1 = JSON.stringify(Lmoji)
|
||||||
|
aa=JSON.parse(str1.replace(/🇹🇼/g," 🇨🇳"))
|
||||||
|
var nname=get_emoji(aa,nname)
|
||||||
|
}
|
||||||
|
var nserver=hd+"tag="+nname.replace(" ️"," ").trim()
|
||||||
|
nlist.push(nserver)
|
||||||
|
}
|
||||||
|
return nlist
|
||||||
|
}
|
||||||
|
|
||||||
//来自 yichahucha 大佬的 Base64 编码/解码: https://github.com/yichahucha/surge/tree/master
|
//来自 yichahucha 大佬的 Base64 编码/解码: https://github.com/yichahucha/surge/tree/master
|
||||||
function Base64() {
|
function Base64() {
|
||||||
// private property
|
// private property
|
||||||
|
|||||||
Reference in New Issue
Block a user