feat(脚本): DNSAPI 申请证书时默认申请主域名

pull/1174/head
mack-a 2025-05-14 16:08:16 +08:00
parent 7eef0d1e5c
commit 090990d93c
1 changed files with 65 additions and 74 deletions

View File

@ -1743,12 +1743,8 @@ initDNSAPIConfig() {
exit 0 exit 0
fi fi
read -r -p "是否使用*.${dnsTLSDomain}进行API申请通配符证书[y/n]:" dnsAPIStatus read -r -p "是否使用*.${dnsTLSDomain}进行API申请通配符证书[y/n]:" dnsAPIStatus
# if [[ "${dnsAPIStatus}" != "y" ]]; then
# exit 0
# fi
fi fi
elif [[ "$1" == "aliyun" ]]; then elif [[ "$1" == "aliyun" ]]; then
# echoContent yellow "\n CF_Token参考配置教程https://www.v2ray-agent.com/archives/1701160377972\n"
read -r -p "请输入Ali Key:" aliKey read -r -p "请输入Ali Key:" aliKey
read -r -p "请输入Ali Secret:" aliSecret read -r -p "请输入Ali Secret:" aliSecret
if [[ -z "${aliKey}" || -z "${aliSecret}" ]]; then if [[ -z "${aliKey}" || -z "${aliSecret}" ]]; then
@ -1761,9 +1757,6 @@ initDNSAPIConfig() {
exit 0 exit 0
fi fi
read -r -p "是否使用*.${dnsTLSDomain}进行API申请通配符证书[y/n]:" dnsAPIStatus read -r -p "是否使用*.${dnsTLSDomain}进行API申请通配符证书[y/n]:" dnsAPIStatus
if [[ "${dnsAPIStatus}" != "y" ]]; then
exit 0
fi
fi fi
fi fi
} }
@ -1828,10 +1821,10 @@ acmeInstallSSL() {
if [[ "${dnsAPIType}" == "cloudflare" ]]; then if [[ "${dnsAPIType}" == "cloudflare" ]]; then
echoContent green " ---> DNS API 生成证书中" echoContent green " ---> DNS API 生成证书中"
sudo CF_Token="${cfAPIToken}" "$HOME/.acme.sh/acme.sh" --issue -d "${dnsAPIDomain}" --dns dns_cf -k ec-256 --server "${sslType}" ${sslIPv6} 2>&1 | tee -a /etc/v2ray-agent/tls/acme.log >/dev/null sudo CF_Token="${cfAPIToken}" "$HOME/.acme.sh/acme.sh" --issue -d "${dnsAPIDomain}" -d "${dnsTLSDomain}" --dns dns_cf -k ec-256 --server "${sslType}" ${sslIPv6} 2>&1 | tee -a /etc/v2ray-agent/tls/acme.log >/dev/null
elif [[ "${dnsAPIType}" == "aliyun" ]]; then elif [[ "${dnsAPIType}" == "aliyun" ]]; then
echoContent green " ---> DNS API 生成证书中" echoContent green " ---> DNS API 生成证书中"
sudo Ali_Key="${aliKey}" Ali_Secret="${aliSecret}" "$HOME/.acme.sh/acme.sh" --issue -d "${dnsAPIDomain}" --dns dns_ali -k ec-256 --server "${sslType}" ${sslIPv6} 2>&1 | tee -a /etc/v2ray-agent/tls/acme.log >/dev/null sudo Ali_Key="${aliKey}" Ali_Secret="${aliSecret}" "$HOME/.acme.sh/acme.sh" --issue -d "${dnsAPIDomain}" -d "${dnsTLSDomain}" --dns dns_ali -k ec-256 --server "${sslType}" ${sslIPv6} 2>&1 | tee -a /etc/v2ray-agent/tls/acme.log >/dev/null
else else
echoContent green " ---> 生成证书中" echoContent green " ---> 生成证书中"
sudo "$HOME/.acme.sh/acme.sh" --issue -d "${tlsDomain}" --standalone -k ec-256 --server "${sslType}" ${sslIPv6} 2>&1 | tee -a /etc/v2ray-agent/tls/acme.log >/dev/null sudo "$HOME/.acme.sh/acme.sh" --issue -d "${tlsDomain}" --standalone -k ec-256 --server "${sslType}" ${sslIPv6} 2>&1 | tee -a /etc/v2ray-agent/tls/acme.log >/dev/null
@ -3979,67 +3972,65 @@ singBoxMergeConfig() {
} }
# 初始化Xray Trojan XTLS 配置文件 # 初始化Xray Trojan XTLS 配置文件
initXrayFrontingConfig() { #initXrayFrontingConfig() {
echoContent red " ---> Trojan暂不支持 xtls-rprx-vision" # echoContent red " ---> Trojan暂不支持 xtls-rprx-vision"
exit 0 # if [[ -z "${configPath}" ]]; then
if [[ -z "${configPath}" ]]; then # echoContent red " ---> 未安装,请使用脚本安装"
echoContent red " ---> 未安装,请使用脚本安装" # menu
menu # exit 0
exit 0 # fi
fi # if [[ "${coreInstallType}" != "1" ]]; then
if [[ "${coreInstallType}" != "1" ]]; then # echoContent red " ---> 未安装可用类型"
echoContent red " ---> 未安装可用类型" # fi
fi # local xtlsType=
local xtlsType= # if echo ${currentInstallProtocolType} | grep -q trojan; then
if echo ${currentInstallProtocolType} | grep -q trojan; then # xtlsType=VLESS
xtlsType=VLESS # else
else # xtlsType=Trojan
xtlsType=Trojan # fi
#
fi # echoContent skyBlue "\n功能 1/${totalProgress} : 前置切换为${xtlsType}"
# echoContent red "\n=============================================================="
echoContent skyBlue "\n功能 1/${totalProgress} : 前置切换为${xtlsType}" # echoContent yellow "# 注意事项\n"
echoContent red "\n==============================================================" # echoContent yellow "会将前置替换为${xtlsType}"
echoContent yellow "# 注意事项\n" # echoContent yellow "如果前置是Trojan查看账号时则会出现两个Trojan协议的节点有一个不可用xtls"
echoContent yellow "会将前置替换为${xtlsType}" # echoContent yellow "再次执行可切换至上一次的前置\n"
echoContent yellow "如果前置是Trojan查看账号时则会出现两个Trojan协议的节点有一个不可用xtls" #
echoContent yellow "再次执行可切换至上一次的前置\n" # echoContent yellow "1.切换至${xtlsType}"
# echoContent red "=============================================================="
echoContent yellow "1.切换至${xtlsType}" # read -r -p "请选择:" selectType
echoContent red "==============================================================" # if [[ "${selectType}" == "1" ]]; then
read -r -p "请选择:" selectType #
if [[ "${selectType}" == "1" ]]; then # if [[ "${xtlsType}" == "Trojan" ]]; then
#
if [[ "${xtlsType}" == "Trojan" ]]; then # local VLESSConfig
# VLESSConfig=$(cat ${configPath}${frontingType}.json)
local VLESSConfig # VLESSConfig=${VLESSConfig//"id"/"password"}
VLESSConfig=$(cat ${configPath}${frontingType}.json) # VLESSConfig=${VLESSConfig//VLESSTCP/TrojanTCPXTLS}
VLESSConfig=${VLESSConfig//"id"/"password"} # VLESSConfig=${VLESSConfig//VLESS/Trojan}
VLESSConfig=${VLESSConfig//VLESSTCP/TrojanTCPXTLS} # VLESSConfig=${VLESSConfig//"vless"/"trojan"}
VLESSConfig=${VLESSConfig//VLESS/Trojan} # VLESSConfig=${VLESSConfig//"id"/"password"}
VLESSConfig=${VLESSConfig//"vless"/"trojan"} #
VLESSConfig=${VLESSConfig//"id"/"password"} # echo "${VLESSConfig}" | jq . >${configPath}02_trojan_TCP_inbounds.json
# rm ${configPath}${frontingType}.json
echo "${VLESSConfig}" | jq . >${configPath}02_trojan_TCP_inbounds.json # elif [[ "${xtlsType}" == "VLESS" ]]; then
rm ${configPath}${frontingType}.json #
elif [[ "${xtlsType}" == "VLESS" ]]; then # local VLESSConfig
# VLESSConfig=$(cat ${configPath}02_trojan_TCP_inbounds.json)
local VLESSConfig # VLESSConfig=${VLESSConfig//"password"/"id"}
VLESSConfig=$(cat ${configPath}02_trojan_TCP_inbounds.json) # VLESSConfig=${VLESSConfig//TrojanTCPXTLS/VLESSTCP}
VLESSConfig=${VLESSConfig//"password"/"id"} # VLESSConfig=${VLESSConfig//Trojan/VLESS}
VLESSConfig=${VLESSConfig//TrojanTCPXTLS/VLESSTCP} # VLESSConfig=${VLESSConfig//"trojan"/"vless"}
VLESSConfig=${VLESSConfig//Trojan/VLESS} # VLESSConfig=${VLESSConfig//"password"/"id"}
VLESSConfig=${VLESSConfig//"trojan"/"vless"} #
VLESSConfig=${VLESSConfig//"password"/"id"} # echo "${VLESSConfig}" | jq . >${configPath}02_VLESS_TCP_inbounds.json
# rm ${configPath}02_trojan_TCP_inbounds.json
echo "${VLESSConfig}" | jq . >${configPath}02_VLESS_TCP_inbounds.json # fi
rm ${configPath}02_trojan_TCP_inbounds.json # reloadCore
fi # fi
reloadCore #
fi # exit 0
#}
exit 0
}
# 初始化sing-box端口 # 初始化sing-box端口
initSingBoxPort() { initSingBoxPort() {
@ -9733,7 +9724,7 @@ menu() {
cd "$HOME" || exit cd "$HOME" || exit
echoContent red "\n==============================================================" echoContent red "\n=============================================================="
echoContent green "作者mack-a" echoContent green "作者mack-a"
echoContent green "当前版本v3.4.11" echoContent green "当前版本v3.4.12"
echoContent green "Githubhttps://github.com/mack-a/v2ray-agent" echoContent green "Githubhttps://github.com/mack-a/v2ray-agent"
echoContent green "描述:八合一共存脚本\c" echoContent green "描述:八合一共存脚本\c"
showInstallStatus showInstallStatus
@ -9780,9 +9771,9 @@ menu() {
2) 2)
selectCoreInstall selectCoreInstall
;; ;;
3) # 3)
initXrayFrontingConfig 1 # initXrayFrontingConfig 1
;; # ;;
4) 4)
manageHysteria manageHysteria
;; ;;