mirror of
				https://github.com/community-scripts/ProxmoxVE.git
				synced 2025-11-04 02:12:49 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			73 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
#!/usr/bin/env bash
 | 
						|
 | 
						|
# Copyright (c) 2021-2025 tteck
 | 
						|
# Author: tteck (tteckster)
 | 
						|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
						|
# Source: https://www.cloudflare.com/
 | 
						|
 | 
						|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | 
						|
color
 | 
						|
verb_ip6
 | 
						|
catch_errors
 | 
						|
setting_up_container
 | 
						|
network_check
 | 
						|
update_os
 | 
						|
 | 
						|
msg_info "Installing Cloudflared"
 | 
						|
mkdir -p --mode=0755 /usr/share/keyrings
 | 
						|
curl -fsSL https://pkg.cloudflare.com/cloudflare-main.gpg >/usr/share/keyrings/cloudflare-main.gpg
 | 
						|
cat <<EOF >/etc/apt/sources.list.d/cloudflared.sources
 | 
						|
Types: deb
 | 
						|
URIs: https://pkg.cloudflare.com/cloudflared/
 | 
						|
Suites: any
 | 
						|
Components: main
 | 
						|
Signed-By: /usr/share/keyrings/cloudflare-main.gpg
 | 
						|
EOF
 | 
						|
$STD apt update
 | 
						|
$STD apt install -y cloudflared
 | 
						|
msg_ok "Installed Cloudflared"
 | 
						|
 | 
						|
read -r -p "${TAB3}Would you like to configure cloudflared as a DNS-over-HTTPS (DoH) proxy? <y/N> " prompt
 | 
						|
if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then
 | 
						|
  msg_info "Creating Service"
 | 
						|
  cat <<EOF >/usr/local/etc/cloudflared/config.yml
 | 
						|
proxy-dns: true
 | 
						|
proxy-dns-address: 0.0.0.0
 | 
						|
proxy-dns-port: 53
 | 
						|
proxy-dns-max-upstream-conns: 5
 | 
						|
proxy-dns-upstream:
 | 
						|
  - https://1.1.1.1/dns-query
 | 
						|
  - https://1.0.0.1/dns-query
 | 
						|
  #- https://8.8.8.8/dns-query
 | 
						|
  #- https://8.8.4.4/dns-query
 | 
						|
  #- https://9.9.9.9/dns-query
 | 
						|
  #- https://149.112.112.112/dns-query
 | 
						|
EOF
 | 
						|
  cat <<EOF >/etc/systemd/system/cloudflared.service
 | 
						|
[Unit]
 | 
						|
Description=cloudflared DNS-over-HTTPS (DoH) proxy
 | 
						|
After=syslog.target network-online.target
 | 
						|
 | 
						|
[Service]
 | 
						|
Type=simple
 | 
						|
ExecStart=/usr/local/bin/cloudflared --config /usr/local/etc/cloudflared/config.yml
 | 
						|
Restart=on-failure
 | 
						|
RestartSec=10
 | 
						|
KillMode=process
 | 
						|
 | 
						|
[Install]
 | 
						|
WantedBy=multi-user.target
 | 
						|
EOF
 | 
						|
  systemctl enable -q --now cloudflared
 | 
						|
  msg_ok "Created Service"
 | 
						|
fi
 | 
						|
 | 
						|
motd_ssh
 | 
						|
customize
 | 
						|
 | 
						|
msg_info "Cleaning up"
 | 
						|
$STD apt -y autoremove
 | 
						|
$STD apt -y autoclean
 | 
						|
$STD apt -y clean
 | 
						|
msg_ok "Cleaned"
 |