tindy2013 / subconverter

Utility to convert between various subscription format
GNU General Public License v3.0
13.21k stars 2.83k forks source link

[BUG] ini格式的配置文件中clash_use_new_field_name无效 #446

Closed RnJ4 closed 2 years ago

RnJ4 commented 2 years ago

确认版本最新

检索issue

subconverter版本

v0.7.1-be420f7

转换过程

profile中的vmess链接

转换设置

[common] ;API mode, set to true to prevent loading local subscriptions or serving local files directly api_mode=false

;Access token used for performing critical action through Web interface api_access_token=xxxxxxx

;Default URLs, used when no URL is provided in request, use "|" to separate multiple subscription links, supports local files/URL default_url=

;Insert subscription links to requests. Can be used to add node(s) to all exported subscriptions. enable_insert=true ;URLs to insert to subscription links, use "|" to separate multiple subscription links, supports local files/URL insert_url= ;Prepend inserted URLs to subscription links. Nodes in insert_url will be added to groups first with non-group-specific match pattern. prepend_insert_url=true

;Exclude nodes which remarks match the following patterns. Supports regular expression. exclude_remarks=(到期|剩余流量|时间|官网|产品) ;exclude_remarks=(other rule)

;Only include nodes which remarks match the following patterns. Supports regular expression. ;include_remarks=V3.*港

;Enable script support for filtering nodes enable_filter=false ;Script used for filtering nodes. Supports inline script and script path. A "filter" function with 1 argument which is a node should be defined in the script. ;Example: Inline script: Set value to content of script. Replace all line break with "\n". ; Script path: Set value to "path:/path/to/script.js". ;filter_script=function filter(node) {\n const info = JSON.parse(node.ProxyInfo);\n if(info.EncryptMethod.includes('chacha20'))\n return true;\n return false;\n}

;Setting an external config file as default when none is specified, supports local files/URL ;default_external_config=config/example_external_config.ini

;The file scope limit of the 'rule_base' options in external configs. base_path=base

;Clash config base used by the generator, supports local files/URL clash_rule_base=base/all_base.tpl

;Surge config base used by the generator, supports local files/URL surge_rule_base=base/all_base.tpl

;Surfboard config base used by the generator, supports local files/URL surfboard_rule_base=base/all_base.tpl

;Mellow config base used by the generator, supports local files/URL mellow_rule_base=base/all_base.tpl

;Quantumult config base used by the generator, supports local files/URL quan_rule_base=base/all_base.tpl

;Quantumult X config base used by the generator, supports local files/URL quanx_rule_base=base/all_base.tpl

;Loon config base used by the generator, supports local files/URL loon_rule_base=base/all_base.tpl

;Shadowsocks Android config base used by the generator, supports local files/URL sssub_rule_base=base/all_base.tpl

;Proxy used to download configs, rulesets or subscriptions, set to NONE or empty to disable it, set to SYSTEM to use system proxy. ;Accept cURL-supported proxies (http:// https:// socks4a:// socks5://) ;Additional support for CORS proxy ( https://github.com/Rob--W/cors-anywhere https://github.com/Zibri/cloudflare-cors-anywhere etc.), prefix the address with "cors:" to recognize the address as CORS proxy. ;Example: http://127.0.0.1:80 socks5://example.com:1080 cors:https://cors-anywhere.herokuapp.com/ proxy_config=SYSTEM proxy_ruleset=SYSTEM proxy_subscription=NONE

;Append a proxy type string ([SS] [SSR] [VMess]) to node remark. append_proxy_type=false

[userinfo] ;Rules to extract stream data from node ;Format: full_match_regex|new_format_regex ;where new_format_regex should be like "total=$1&left=$2&used=$3" stream_rule=^剩余流量:(.?)|总流量:(.)$|total=$2&left=$1 stream_rule=^剩余流量:(.?) (.)$|total=$1&left=$2 stream_rule=^Bandwidth: (.?)/(.)$|used=$1&total=$2 stream_rule=^[.?]剩余(.?)@(?:.)$|total=$1 stream_rule=^.?流量:(.?) 剩:(?:.)$|total=$1

;Rules to extract expire time data from node ;Format: full_match_regex|new_format_regex ;where new_format_regex should follow this example: yyyy:mm:dd:hh:mm:ss time_rule=^过期时间:(\d+)-(\d+)-(\d+) (\d+):(\d+):(\d+)$|$1:$2:$3:$4:$5:$6 time_rule=^到期时间(:|:)(\d+)-(\d+)-(\d+)$|$1:$2:$3:0:0:0 time_rule=^Smart Access expire: (\d+)/(\d+)/(\d+)$|$1:$2:$3:0:0:0 time_rule=^.?流量:(?:.?) 剩:(.*)$|left=$1d

[node_pref] ;udp_flag=false ;tcp_fast_open_flag=false ;skip_cert_verify_flag=false ;tls13_flag=false

sort_flag=false ;Script used for sorting nodes. A "compare" function with 2 arguments which are the 2 nodes to be compared should be defined in the script. Supports inline script and script path. ;Examples can be seen at the filter_script option in [common] section. ;sort_script=function compare(node_a, node_b) {\n const info_a = JSON.parse(node_a.ProxyInfo);\n const info_b = JSON.parse(node_b.ProxyInfo);\n return info_a.Remark > info_b.Remark;\n}

filter_deprecated_nodes=false append_sub_userinfo=true clash_use_new_field_name=true

;Generate style of the proxies section of Clash subscriptions. ;Supported styles: block, flow, compact ;Block: - name: name1 Flow: - {name: name1, key: value} Compact: [{name: name1, key: value},{name: name2, key: value}] ; key: value - {name: name2, key: value} ; - name: name2 ; key: value clash_proxies_style=flow

;Rename remarks with the following patterns. Supports regular expression. ;Format: Search_Pattern@Replace_Pattern ;rename_node=IPLC@专线 ;rename_node=RELAY@中转 ;rename_node=BGP-@ ;rename_node=!!script:function rename(node) {\n const info = JSON.parse(node.ProxyInfo);\n const geoinfo = JSON.parse(geoip(info.Hostname));\n if(geoinfo.country_code == "CN")\n return "CN " + node.Remark;\n} ;rename_node=!!script:path:/path/to/script.js

rename_node=!!import:snippets/rename_node.txt

[managed_config] ;Append a '#!MANAGED-CONFIG' info to Surge configurations write_managed_config=true

;Address prefix for MANAGED-CONFIG info, without the trailing "/". ;This address will also be used for generating /getruleset, /qx-rewrite, /qx-script addresses. managed_config_prefix=http://127.0.0.1:25500

;Managed config update interval in seconds, determine how long the config will be updated. config_update_interval=86400

;If config_update_strict is set to true, Surge will require a force update after the interval. config_update_strict=false

;Device ID to be written to rewrite scripts for some version of Quantumult X quanx_device_id=

[surge_external_proxy] ;surge_ssr_path=/usr/bin/ssr-local resolve_hostname=true

[emojis] add_emoji=true remove_old_emoji=true

;Rule to add emojis. Supports regular expression. ;Format: Remark_Search_Pattern,emoji

;rule=(流量|时间|应急|过期|Bandwidth|expire),🏳️‍🌈 ;rule=AC,🇦🇨 ;rule=!!script:function getEmoji(node) {\n const info = JSON.parse(node.ProxyInfo);\n const geoinfo = JSON.parse(geoip(info.Hostname));\n if(geoinfo.country_code == "CN")\n return "🏳️‍🌈";\n} ;rule=!!script:path:/path/to/script/.js

rule=!!import:snippets/emoji.txt

[rulesets] ;Enable generating rules with rulesets enabled=true

;Overwrite the existing rules in rule_base overwrite_original_rules=false

;Perform a ruleset update on request update_ruleset_on_request=false

;Ruleset addresses, supports local files/URL ;Format: Group name,[type:]URL[,interval] ; Group name,[]Rule ;where "type" supports the following value: surge, quanx, clash-domain, clash-ipcidr, clash-classic ;type defaults to surge if omitted

;ruleset=DIRECT,https://raw.githubusercontent.com/DivineEngine/Profiles/master/Surge/Ruleset/Guard/Unbreak.list,86400 ;ruleset=🎯 全球直连,rules/LocalAreaNetwork.list ;ruleset=DIRECT,surge:rules/LocalAreaNetwork.list ;ruleset=Advertising,quanx:https://raw.githubusercontent.com/DivineEngine/Profiles/master/Quantumult/Filter/Guard/Advertising.list,86400 ;ruleset=Domestic Services,clash-domain:https://ruleset.dev/clash_domestic_services_domains,86400 ;ruleset=Domestic Services,clash-ipcidr:https://ruleset.dev/clash_domestic_services_ips,86400 ;ruleset=DIRECT,clash-classic:https://raw.githubusercontent.com/DivineEngine/Profiles/master/Clash/RuleSet/China.yaml,86400 ;ruleset=🎯 全球直连,[]GEOIP,CN ;ruleset=🐟 漏网之鱼,[]FINAL ruleset=!!import:snippets/rulesets.txt

[proxy_groups] ;Generate Clash Proxy Group with the following patterns. Node filtering rule supports regular expression. ;Format: Group_NameselectRule_1Rule_2... ; Group_Nameurl-test|fallback|load-balanceRule_1Rule_2...test_urlinterval[,timeout][,tolerance] ;Rule with "[]" prefix will be added directly.

;custom_proxy_group=Proxyselect.[]AUTO[]DIRECT`. ;custom_proxy_group=UrlTesturl-test.http://www.gstatic.com/generate_204300,5,100 ;custom_proxy_group=FallBackfallback.http://www.gstatic.com/generate_204300,5 ;custom_proxy_group=LoadBalanceload-balance.*http://www.gstatic.com/generate_204300,,100 ;custom_proxy_group=SSIDssiddefault_group`celluar=group0,ssid1=group1,ssid2=group2

;custom_proxy_group=g1select!!GROUPID=0 ;custom_proxy_group=g2select!!GROUPID=1 ;custom_proxy_group=v2rayselect!!GROUP=V2RayProvider

;custom_proxy_group=g1hkselect!!GROUPID=0!!(HGC|HKBN|PCCW|HKT|hk|港) ;custom_proxy_group=sstwselect!!GROUP=V2RayProvider!!(深台|彰化|新北|台|tw) ;custom_proxy_group=providerselect!!PROVIDER=prov1,prov2,prov3`fallback_nodes

;Also supports using script for filtering nodes. A "filter" function with one argument which is an array of all available nodes should be defined in the script. ;custom_proxy_group=scriptselectscript:/path/to/script.js

;for forcerule.yml ;custom_proxy_group=!!import:snippets/groups_forcerule.txt

;for Surge rulesets custom_proxy_group=!!import:snippets/groups.txt

[template] ;The file scope limit of 'include' statement inside the templates. template_path=templates

;The following settings will be added to the "global" scope of the template variables ;Value of 'clash.http_port' can be accessed with 'global.clash.http_port' in the template. clash.http_port=7890 clash.socks_port=7891 clash.allow_lan=true clash.log_level=info

[aliases] ;Aliases for accessing interfaces. Can be used to shorten the URI. ;All arguments passed when accessing the alias name will be appended to the arguments of the alias target. ;Format: uri=target /v=/version /clash=/sub?target=clash /clashr=/sub?target=clashr /surge=/sub?target=surge /quan=/sub?target=quan /quanx=/sub?target=quanx /mellow=/sub?target=mellow /surfboard=/sub?target=surfboard /loon=/sub?target=loon /ss=/sub?target=ss /ssd=/sub?target=ssd /sssub=/sub?target=sssub /ssr=/sub?target=ssr /v2ray=/sub?target=v2ray /trojan=/sub?target=trojan

[server] ;Address to bind on for Web Server listen=0.0.0.0

;Port to bind on for Web Server port=25501

;Root folder for web server, keep empty to disable serve_file_root=

[advanced] log_level=info print_debug_info=false max_pending_connections=10240 max_concurrent_threads=2 max_allowed_rulesets=0 max_allowed_rules=0 max_allowed_download_size=0 enable_cache=false cache_subscription=60 cache_config=300 cache_ruleset=21600 script_clean_context=true async_fetch_ruleset=false skip_failed_links=false

复现步骤

使用如上配置运行subconverter(从pref.example.ini复制的,只改了token和端口) 将vmess链接写入profile/1.ini http get getprofile?name=profiles/1.ini&token=xxxx

期望结果

输出新版clash可用的vmess ws配置

实际结果

输出的配置仍为旧版

错误信息

No response

RnJ4 commented 2 years ago

使用yml格式的配置文件则可以正常生成新版配置,无此问题

miyouzi commented 2 years ago

在调用接口时使用 new_name 参数同样无效(使用 pref.ini 格式)

tindy2013 commented 2 years ago

无法复现