mirror of https://github.com/tteck/Proxmox.git
				
				
				
			Create blocky-install.sh
This commit is contained in:
		
							parent
							
								
									23da0e4655
								
							
						
					
					
						commit
						b658f5fcde
					
				| 
						 | 
				
			
			@ -0,0 +1,355 @@
 | 
			
		|||
#!/usr/bin/env bash
 | 
			
		||||
YW=`echo "\033[33m"`
 | 
			
		||||
RD=`echo "\033[01;31m"`
 | 
			
		||||
BL=`echo "\033[36m"`
 | 
			
		||||
GN=`echo "\033[1;92m"`
 | 
			
		||||
CL=`echo "\033[m"`
 | 
			
		||||
RETRY_NUM=10
 | 
			
		||||
RETRY_EVERY=3
 | 
			
		||||
NUM=$RETRY_NUM
 | 
			
		||||
CM="${GN}✓${CL}"
 | 
			
		||||
CROSS="${RD}✗${CL}"
 | 
			
		||||
BFR="\\r\\033[K"
 | 
			
		||||
HOLD="-"
 | 
			
		||||
set -o errexit
 | 
			
		||||
set -o errtrace
 | 
			
		||||
set -o nounset
 | 
			
		||||
set -o pipefail
 | 
			
		||||
shopt -s expand_aliases
 | 
			
		||||
alias die='EXIT=$? LINE=$LINENO error_exit'
 | 
			
		||||
trap die ERR
 | 
			
		||||
 | 
			
		||||
function error_exit() {
 | 
			
		||||
  trap - ERR
 | 
			
		||||
  local reason="Unknown failure occurred."
 | 
			
		||||
  local msg="${1:-$reason}"
 | 
			
		||||
  local flag="${RD}‼ ERROR ${CL}$EXIT@$LINE"
 | 
			
		||||
  echo -e "$flag $msg" 1>&2
 | 
			
		||||
  exit $EXIT
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function msg_info() {
 | 
			
		||||
    local msg="$1"
 | 
			
		||||
    echo -ne " ${HOLD} ${YW}${msg}..."
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function msg_ok() {
 | 
			
		||||
    local msg="$1"
 | 
			
		||||
    echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
 | 
			
		||||
}
 | 
			
		||||
function msg_error() {
 | 
			
		||||
    local msg="$1"
 | 
			
		||||
    echo -e "${BFR} ${CROSS} ${RD}${msg}${CL}"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up Container OS "
 | 
			
		||||
sed -i "/$LANG/ s/\(^# \)//" /etc/locale.gen
 | 
			
		||||
locale-gen >/dev/null
 | 
			
		||||
while [ "$(hostname -I)" = "" ]; do
 | 
			
		||||
  1>&2 echo -en "${CROSS}${RD} No Network! "
 | 
			
		||||
  sleep $RETRY_EVERY
 | 
			
		||||
  ((NUM--))
 | 
			
		||||
  if [ $NUM -eq 0 ]
 | 
			
		||||
  then
 | 
			
		||||
    1>&2 echo -e "${CROSS}${RD} No Network After $RETRY_NUM Tries${CL}"    
 | 
			
		||||
    exit 1
 | 
			
		||||
  fi
 | 
			
		||||
done
 | 
			
		||||
msg_ok "Set up Container OS"
 | 
			
		||||
msg_ok "Network Connected: ${BL}$(hostname -I)"
 | 
			
		||||
 | 
			
		||||
if nc -zw1 8.8.8.8 443; then  msg_ok "Internet Connected"; else  msg_error "Internet NOT Connected"; exit 1; fi;
 | 
			
		||||
RESOLVEDIP=$(nslookup "github.com" | awk -F':' '/^Address: / { matched = 1 } matched { print $2}' | xargs)
 | 
			
		||||
if [[ -z "$RESOLVEDIP" ]]; then msg_error "DNS Lookup Failure";  else msg_ok "DNS Resolved github.com to $RESOLVEDIP";  fi;
 | 
			
		||||
 | 
			
		||||
msg_info "Updating Container OS"
 | 
			
		||||
apt-get update &>/dev/null
 | 
			
		||||
apt-get -y upgrade &>/dev/null
 | 
			
		||||
msg_ok "Updated Container OS"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
apt-get install -y curl &>/dev/null
 | 
			
		||||
apt-get install -y sudo &>/dev/null
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Blocky"
 | 
			
		||||
RELEASE=$(curl -s https://api.github.com/repos/0xERR0R/blocky/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
			
		||||
wget https://github.com/0xERR0R/blocky/releases/download/v$RELEASE/blocky_${RELEASE}_Linux_x86_64.tar.gz &>/dev/null
 | 
			
		||||
mkdir -p /opt/blocky
 | 
			
		||||
tar -xf blocky_0.19_Linux_x86_64.tar.gz -C /opt/blocky
 | 
			
		||||
rm -rf blocky_${RELEASE}_Linux_x86_64.tar.gz
 | 
			
		||||
cat << EOF > /opt/blocky/config.yml
 | 
			
		||||
upstream:
 | 
			
		||||
  # these external DNS resolvers will be used. Blocky picks 2 random resolvers from the list for each query
 | 
			
		||||
  # format for resolver: [net:]host:[port][/path]. net could be empty (default, shortcut for tcp+udp), tcp+udp, tcp, udp, tcp-tls or https (DoH). If port is empty, default port will be used (53 for udp and tcp, 853 for tcp-tls, 443 for https (Doh))
 | 
			
		||||
  # this configuration is mandatory, please define at least one external DNS resolver
 | 
			
		||||
  default:
 | 
			
		||||
    # example for tcp+udp IPv4 server (https://digitalcourage.de/)
 | 
			
		||||
    #- 5.9.164.112
 | 
			
		||||
    # Cloudflare
 | 
			
		||||
    - 1.1.1.1
 | 
			
		||||
    # example for DNS-over-TLS server (DoT)
 | 
			
		||||
    #- tcp-tls:fdns1.dismail.de:853
 | 
			
		||||
    # example for DNS-over-HTTPS (DoH)
 | 
			
		||||
    #- https://dns.digitale-gesellschaft.ch/dns-query
 | 
			
		||||
  # optional: use client name (with wildcard support: * - sequence of any characters, [0-9] - range)
 | 
			
		||||
  # or single ip address / client subnet as CIDR notation
 | 
			
		||||
  #laptop*:
 | 
			
		||||
    #- 123.123.123.123
 | 
			
		||||
 | 
			
		||||
# optional: timeout to query the upstream resolver. Default: 2s
 | 
			
		||||
#upstreamTimeout: 2s
 | 
			
		||||
 | 
			
		||||
# optional: If true, blocky will fail to start unless at least one upstream server per group is reachable. Default: false
 | 
			
		||||
#startVerifyUpstream: true
 | 
			
		||||
 | 
			
		||||
# optional: Determines how blocky will create outgoing connections. This impacts both upstreams, and lists.
 | 
			
		||||
# accepted: dual, v4, v6
 | 
			
		||||
# default: dual
 | 
			
		||||
#connectIPVersion: dual
 | 
			
		||||
 | 
			
		||||
# optional: custom IP address(es) for domain name (with all sub-domains). Multiple addresses must be separated by a comma
 | 
			
		||||
# example: query "printer.lan" or "my.printer.lan" will return 192.168.178.3
 | 
			
		||||
#customDNS:
 | 
			
		||||
  #customTTL: 1h
 | 
			
		||||
  # optional: if true (default), return empty result for unmapped query types (for example TXT, MX or AAAA if only IPv4 address is defined).
 | 
			
		||||
  # if false, queries with unmapped types will be forwarded to the upstream resolver
 | 
			
		||||
  #filterUnmappedTypes: true
 | 
			
		||||
  # optional: replace domain in the query with other domain before resolver lookup in the mapping
 | 
			
		||||
  #rewrite:
 | 
			
		||||
    #example.com: printer.lan
 | 
			
		||||
  #mapping:
 | 
			
		||||
    #printer.lan: 192.168.178.3,2001:0db8:85a3:08d3:1319:8a2e:0370:7344
 | 
			
		||||
 | 
			
		||||
# optional: definition, which DNS resolver(s) should be used for queries to the domain (with all sub-domains). Multiple resolvers must be separated by a comma
 | 
			
		||||
# Example: Query client.fritz.box will ask DNS server 192.168.178.1. This is necessary for local network, to resolve clients by host name
 | 
			
		||||
#conditional:
 | 
			
		||||
  # optional: if false (default), return empty result if after rewrite, the mapped resolver returned an empty answer. If true, the original query will be sent to the upstream resolver
 | 
			
		||||
  # Example: The query "blog.example.com" will be rewritten to "blog.fritz.box" and also redirected to the resolver at 192.168.178.1. If not found and if  was set to , the original query "blog.example.com" will be sent upstream.
 | 
			
		||||
  # Usage: One usecase when having split DNS for internal and external (internet facing) users, but not all subdomains are listed in the internal domain.
 | 
			
		||||
  #fallbackUpstream: false
 | 
			
		||||
  # optional: replace domain in the query with other domain before resolver lookup in the mapping
 | 
			
		||||
  #rewrite:
 | 
			
		||||
    #example.com: fritz.box
 | 
			
		||||
  #mapping:
 | 
			
		||||
    #fritz.box: 192.168.178.1
 | 
			
		||||
    #lan.net: 192.168.178.1,192.168.178.2
 | 
			
		||||
 | 
			
		||||
# optional: use black and white lists to block queries (for example ads, trackers, adult pages etc.)
 | 
			
		||||
blocking:
 | 
			
		||||
  # definition of blacklist groups. Can be external link (http/https) or local file
 | 
			
		||||
  blackLists:
 | 
			
		||||
    ads:
 | 
			
		||||
      - https://s3.amazonaws.com/lists.disconnect.me/simple_ad.txt
 | 
			
		||||
      - https://raw.githubusercontent.com/StevenBlack/hosts/master/hosts
 | 
			
		||||
      - http://sysctl.org/cameleon/hosts
 | 
			
		||||
      - https://s3.amazonaws.com/lists.disconnect.me/simple_tracking.txt
 | 
			
		||||
      - |
 | 
			
		||||
        # inline definition with YAML literal block scalar style
 | 
			
		||||
        # hosts format
 | 
			
		||||
        someadsdomain.com
 | 
			
		||||
    special:
 | 
			
		||||
      - https://raw.githubusercontent.com/StevenBlack/hosts/master/alternates/fakenews/hosts
 | 
			
		||||
  # definition of whitelist groups. Attention: if the same group has black and whitelists, whitelists will be used to disable particular blacklist entries. If a group has only whitelist entries -> this means only domains from this list are allowed, all other domains will be blocked
 | 
			
		||||
  whiteLists:
 | 
			
		||||
    ads:
 | 
			
		||||
      - whitelist.txt
 | 
			
		||||
      - |
 | 
			
		||||
        # inline definition with YAML literal block scalar style
 | 
			
		||||
        # hosts format
 | 
			
		||||
        whitelistdomain.com
 | 
			
		||||
        # this is a regex
 | 
			
		||||
        /^banners?[_.-]/
 | 
			
		||||
  # definition: which groups should be applied for which client
 | 
			
		||||
  clientGroupsBlock:
 | 
			
		||||
    # default will be used, if no special definition for a client name exists
 | 
			
		||||
    default:
 | 
			
		||||
      - ads
 | 
			
		||||
      - special
 | 
			
		||||
    # use client name (with wildcard support: * - sequence of any characters, [0-9] - range)
 | 
			
		||||
    # or single ip address / client subnet as CIDR notation
 | 
			
		||||
    #laptop*:
 | 
			
		||||
      #- ads
 | 
			
		||||
    #192.168.178.1/24:
 | 
			
		||||
      #- special
 | 
			
		||||
  # which response will be sent, if query is blocked:
 | 
			
		||||
  # zeroIp: 0.0.0.0 will be returned (default)
 | 
			
		||||
  # nxDomain: return NXDOMAIN as return code
 | 
			
		||||
  # comma separated list of destination IP addresses (for example: 192.100.100.15, 2001:0db8:85a3:08d3:1319:8a2e:0370:7344). Should contain ipv4 and ipv6 to cover all query types. Useful with running web server on this address to display the "blocked" page.
 | 
			
		||||
  blockType: zeroIp
 | 
			
		||||
  # optional: TTL for answers to blocked domains
 | 
			
		||||
  # default: 6h
 | 
			
		||||
  blockTTL: 1m
 | 
			
		||||
  # optional: automatically list refresh period (in duration format). Default: 4h.
 | 
			
		||||
  # Negative value -> deactivate automatically refresh.
 | 
			
		||||
  # 0 value -> use default
 | 
			
		||||
  refreshPeriod: 4h
 | 
			
		||||
  # optional: timeout for list download (each url). Default: 60s. Use large values for big lists or slow internet connections
 | 
			
		||||
  downloadTimeout: 4m
 | 
			
		||||
  # optional: Download attempt timeout. Default: 60s
 | 
			
		||||
  downloadAttempts: 5
 | 
			
		||||
  # optional: Time between the download attempts. Default: 1s
 | 
			
		||||
  downloadCooldown: 10s
 | 
			
		||||
  # optional: if failOnError, application startup will fail if at least one list can't be downloaded / opened. Default: blocking
 | 
			
		||||
  #startStrategy: failOnError
 | 
			
		||||
 | 
			
		||||
# optional: configuration for caching of DNS responses
 | 
			
		||||
caching:
 | 
			
		||||
  # duration how long a response must be cached (min value).
 | 
			
		||||
  # If <=0, use response's TTL, if >0 use this value, if TTL is smaller
 | 
			
		||||
  # Default: 0
 | 
			
		||||
  minTime: 5m
 | 
			
		||||
  # duration how long a response must be cached (max value).
 | 
			
		||||
  # If <0, do not cache responses
 | 
			
		||||
  # If 0, use TTL
 | 
			
		||||
  # If > 0, use this value, if TTL is greater
 | 
			
		||||
  # Default: 0
 | 
			
		||||
  maxTime: 30m
 | 
			
		||||
  # Max number of cache entries (responses) to be kept in cache (soft limit). Useful on systems with limited amount of RAM.
 | 
			
		||||
  # Default (0): unlimited
 | 
			
		||||
  maxItemsCount: 0
 | 
			
		||||
  # if true, will preload DNS results for often used queries (default: names queried more than 5 times in a 2-hour time window)
 | 
			
		||||
  # this improves the response time for often used queries, but significantly increases external traffic
 | 
			
		||||
  # default: false
 | 
			
		||||
  prefetching: true
 | 
			
		||||
  # prefetch track time window (in duration format)
 | 
			
		||||
  # default: 120
 | 
			
		||||
  prefetchExpires: 2h
 | 
			
		||||
  # name queries threshold for prefetch
 | 
			
		||||
  # default: 5
 | 
			
		||||
  prefetchThreshold: 5
 | 
			
		||||
  # Max number of domains to be kept in cache for prefetching (soft limit). Useful on systems with limited amount of RAM.
 | 
			
		||||
  # Default (0): unlimited
 | 
			
		||||
  #prefetchMaxItemsCount: 0
 | 
			
		||||
 | 
			
		||||
# optional: configuration of client name resolution
 | 
			
		||||
clientLookup:
 | 
			
		||||
  # optional: this DNS resolver will be used to perform reverse DNS lookup (typically local router)
 | 
			
		||||
  #upstream: 192.168.178.1
 | 
			
		||||
  # optional: some routers return multiple names for client (host name and user defined name). Define which single name should be used.
 | 
			
		||||
  # Example: take second name if present, if not take first name
 | 
			
		||||
  #singleNameOrder:
 | 
			
		||||
    #- 2
 | 
			
		||||
    #- 1
 | 
			
		||||
  # optional: custom mapping of client name to IP addresses. Useful if reverse DNS does not work properly or just to have custom client names.
 | 
			
		||||
  #clients:
 | 
			
		||||
    #laptop:
 | 
			
		||||
      #- 192.168.178.29
 | 
			
		||||
# optional: configuration for prometheus metrics endpoint
 | 
			
		||||
prometheus:
 | 
			
		||||
  # enabled if true
 | 
			
		||||
  #enable: true
 | 
			
		||||
  # url path, optional (default '/metrics')
 | 
			
		||||
  #path: /metrics
 | 
			
		||||
 | 
			
		||||
# optional: write query information (question, answer, client, duration etc.) to daily csv file
 | 
			
		||||
queryLog:
 | 
			
		||||
  # optional one of: mysql, postgresql, csv, csv-client. If empty, log to console
 | 
			
		||||
  #type: mysql
 | 
			
		||||
  # directory (should be mounted as volume in docker) for csv, db connection string for mysql/postgresql
 | 
			
		||||
  #target: db_user:db_password@tcp(db_host_or_ip:3306)/db_name?charset=utf8mb4&parseTime=True&loc=Local
 | 
			
		||||
  #postgresql target: postgres://user:password@db_host_or_ip:5432/db_name
 | 
			
		||||
  # if > 0, deletes log files which are older than ... days
 | 
			
		||||
  #logRetentionDays: 7
 | 
			
		||||
  # optional: Max attempts to create specific query log writer, default: 3
 | 
			
		||||
  #creationAttempts: 1
 | 
			
		||||
  # optional: Time between the creation attempts, default: 2s
 | 
			
		||||
  #creationCooldown: 2s
 | 
			
		||||
 | 
			
		||||
# optional: Blocky can synchronize its cache and blocking state between multiple instances through redis.
 | 
			
		||||
redis:
 | 
			
		||||
  # Server address and port
 | 
			
		||||
  #address: redis:6379
 | 
			
		||||
  # Password if necessary
 | 
			
		||||
  #password: passwd
 | 
			
		||||
  # Database, default: 0
 | 
			
		||||
  #database: 2
 | 
			
		||||
  # Connection is required for blocky to start. Default: false
 | 
			
		||||
  #required: true
 | 
			
		||||
  # Max connection attempts, default: 3
 | 
			
		||||
  #connectionAttempts: 10
 | 
			
		||||
  # Time between the connection attempts, default: 1s
 | 
			
		||||
  #connectionCooldown: 3s
 | 
			
		||||
 | 
			
		||||
# optional: DNS listener port(s) and bind ip address(es), default 53 (UDP and TCP). Example: 53, :53, "127.0.0.1:5353,[::1]:5353"
 | 
			
		||||
port: 553
 | 
			
		||||
# optional: Port(s) and bind ip address(es) for DoT (DNS-over-TLS) listener. Example: 853, 127.0.0.1:853
 | 
			
		||||
#tlsPort: 853
 | 
			
		||||
# optional: HTTPS listener port(s) and bind ip address(es), default empty = no http listener. If > 0, will be used for prometheus metrics, pprof, REST API, DoH... Example: 443, :443, 127.0.0.1:443
 | 
			
		||||
#httpPort: 4000
 | 
			
		||||
#httpsPort: 443
 | 
			
		||||
# optional: Mininal TLS version that the DoH and DoT server will use
 | 
			
		||||
#minTlsServeVersion: 1.3
 | 
			
		||||
# if https port > 0: path to cert and key file for SSL encryption. if not set, self-signed certificate will be generated
 | 
			
		||||
#certFile: server.crt
 | 
			
		||||
#keyFile: server.key
 | 
			
		||||
# optional: use this DNS server to resolve blacklist urls and upstream DNS servers. Useful if no DNS resolver is configured and blocky needs to resolve a host name. Format net:IP:port, net must be udp or tcp
 | 
			
		||||
#bootstrapDns: tcp+udp:1.1.1.1
 | 
			
		||||
 | 
			
		||||
filtering:
 | 
			
		||||
# optional: drop all queries with following query types. Default: empty
 | 
			
		||||
  #queryTypes:
 | 
			
		||||
    #- AAAA
 | 
			
		||||
 | 
			
		||||
# optional: if path defined, use this file for query resolution (A, AAAA and rDNS). Default: empty
 | 
			
		||||
hostsFile:
 | 
			
		||||
  # optional: Path to hosts file (e.g. /etc/hosts on Linux)
 | 
			
		||||
  #filePath: /etc/hosts
 | 
			
		||||
  # optional: TTL, default: 1h
 | 
			
		||||
  #hostsTTL: 60m
 | 
			
		||||
  # optional: Time between hosts file refresh, default: 1h
 | 
			
		||||
  #refreshPeriod: 30m
 | 
			
		||||
  # optional: Whether loopback hosts addresses (127.0.0.0/8 and ::1) should be filtered or not, default: false
 | 
			
		||||
  #filterLoopback: true
 | 
			
		||||
# optional: Log level (one from debug, info, warn, error). Default: info
 | 
			
		||||
#logLevel: info
 | 
			
		||||
# optional: Log format (text or json). Default: text
 | 
			
		||||
#logFormat: text
 | 
			
		||||
# optional: log timestamps. Default: true
 | 
			
		||||
#logTimestamp: true
 | 
			
		||||
# optional: obfuscate log output (replace all alphanumeric characters with *) for user sensitive data like request domains or responses to increase privacy. Default: false
 | 
			
		||||
#logPrivacy: false
 | 
			
		||||
 | 
			
		||||
# optional: add EDE error codes to dns response
 | 
			
		||||
#ede: 
 | 
			
		||||
  # enabled if true, Default: false
 | 
			
		||||
  #enable: true
 | 
			
		||||
EOF
 | 
			
		||||
msg_ok "Installed Blocky"
 | 
			
		||||
 | 
			
		||||
msg_info "Creating Service"
 | 
			
		||||
cat << EOF > /etc/systemd/system/blocky.service
 | 
			
		||||
[Unit]
 | 
			
		||||
Description=Blocky
 | 
			
		||||
After=network.target
 | 
			
		||||
[Service]
 | 
			
		||||
User=root
 | 
			
		||||
WorkingDirectory=/opt/blocky
 | 
			
		||||
ExecStart=/opt/blocky/./blocky --config config.yml
 | 
			
		||||
[Install]
 | 
			
		||||
WantedBy=multi-user.target
 | 
			
		||||
EOF
 | 
			
		||||
systemctl enable --now blocky
 | 
			
		||||
msg_ok "Created Service"
 | 
			
		||||
 | 
			
		||||
PASS=$(grep -w "root" /etc/shadow | cut -b6);
 | 
			
		||||
  if [[ $PASS != $ ]]; then
 | 
			
		||||
msg_info "Customizing Container"
 | 
			
		||||
chmod -x /etc/update-motd.d/*
 | 
			
		||||
touch ~/.hushlogin
 | 
			
		||||
GETTY_OVERRIDE="/etc/systemd/system/container-getty@1.service.d/override.conf"
 | 
			
		||||
mkdir -p $(dirname $GETTY_OVERRIDE)
 | 
			
		||||
cat << EOF > $GETTY_OVERRIDE
 | 
			
		||||
[Service]
 | 
			
		||||
ExecStart=
 | 
			
		||||
ExecStart=-/sbin/agetty --autologin root --noclear --keep-baud tty%I 115200,38400,9600 \$TERM
 | 
			
		||||
EOF
 | 
			
		||||
systemctl daemon-reload
 | 
			
		||||
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
 | 
			
		||||
msg_ok "Customized Container"
 | 
			
		||||
  fi
 | 
			
		||||
  
 | 
			
		||||
msg_info "Cleaning up"
 | 
			
		||||
apt-get autoremove >/dev/null
 | 
			
		||||
apt-get autoclean >/dev/null
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
		Loading…
	
		Reference in New Issue