mirror of
https://github.com/flynx/proxmox-utils.git
synced 2025-12-25 21:02:04 +00:00
Compare commits
11 Commits
3527c7db01
...
31dbf3acd2
| Author | SHA1 | Date | |
|---|---|---|---|
| 31dbf3acd2 | |||
| f2e160acc4 | |||
| e8d45394de | |||
| 99bcb0d20f | |||
| 438fc83115 | |||
| a1d805a751 | |||
| 51b827d15e | |||
| 8e6d39eb42 | |||
| 36689166d5 | |||
| 37037a3a43 | |||
| ff40c4bbb1 |
@ -36,6 +36,8 @@ ADMIN_BRIDGE=
|
|||||||
DFL_WAN_IP=192.168.1.101/24
|
DFL_WAN_IP=192.168.1.101/24
|
||||||
DFL_WAN_GATE=192.168.1.252
|
DFL_WAN_GATE=192.168.1.252
|
||||||
|
|
||||||
|
DFL_WAN_SSH_IP:192.168.1.102/24
|
||||||
|
|
||||||
|
|
||||||
# Doman and email configuration
|
# Doman and email configuration
|
||||||
#
|
#
|
||||||
|
|||||||
@ -7,7 +7,7 @@ enable: 1
|
|||||||
|
|
||||||
[RULES]
|
[RULES]
|
||||||
|
|
||||||
IN ACCEPT -i vmbr3 -log nolog # STUB
|
IN ACCEPT -i vmbr3 -log nolog # ADMIN
|
||||||
IN REJECT -i vmbr0 -p udp -dport 68 -sport 68 -log nolog # dhcp
|
IN REJECT -i vmbr0 -p udp -dport 68 -sport 68 -log nolog # dhcp
|
||||||
IN REJECT -i vmbr0 -p udp -dport 67 -sport 67 -log nolog # dhcp
|
IN REJECT -i vmbr0 -p udp -dport 67 -sport 67 -log nolog # dhcp
|
||||||
OUT REJECT -i vmbr0 -p udp -dport 68 -sport 68 -log nolog # dhcp
|
OUT REJECT -i vmbr0 -p udp -dport 68 -sport 68 -log nolog # dhcp
|
||||||
@ -17,6 +17,8 @@ OUT DHCPfwd(REJECT) -i vmbr0 -log nolog
|
|||||||
IN DNS(ACCEPT) -i vmbr0 -log nolog
|
IN DNS(ACCEPT) -i vmbr0 -log nolog
|
||||||
IN Ping(ACCEPT) -i vmbr0 -log nolog
|
IN Ping(ACCEPT) -i vmbr0 -log nolog
|
||||||
IN SSH(ACCEPT) -i vmbr0 -log nolog
|
IN SSH(ACCEPT) -i vmbr0 -log nolog
|
||||||
|
IN ACCEPT -i vmbr0 -p udp -dport 51820 -log nolog # Wireguard
|
||||||
|
IN ACCEPT -i vmbr0 -p udp -dport 51821 -log nolog # Wireguard (alt)
|
||||||
|IN OpenVPN(ACCEPT) -i vmbr0 -log nolog
|
|IN OpenVPN(ACCEPT) -i vmbr0 -log nolog
|
||||||
IN Web(ACCEPT) -i vmbr0 -log nolog
|
IN Web(ACCEPT) -i vmbr0 -log nolog
|
||||||
IN ACCEPT -i vmbr0 -p udp -dport 22027 -log nolog # syncthing
|
IN ACCEPT -i vmbr0 -p udp -dport 22027 -log nolog # syncthing
|
||||||
|
|||||||
@ -34,6 +34,9 @@ LAN_GATE=SKIP
|
|||||||
|
|
||||||
REBOOT=${REBOOT:=1}
|
REBOOT=${REBOOT:=1}
|
||||||
|
|
||||||
|
DFL_WAN_SSH_IP=${DFL_WAN_SSH_IP:=}
|
||||||
|
xread "WAN ssh ip:" WAN_SSH_IP
|
||||||
|
|
||||||
readVars
|
readVars
|
||||||
|
|
||||||
|
|
||||||
@ -47,6 +50,7 @@ OPTS_STAGE_1="\
|
|||||||
--swap $SWAP \
|
--swap $SWAP \
|
||||||
--net0 name=lan,bridge=vmbr${LAN_BRIDGE},firewall=1,ip=dhcp,type=veth \
|
--net0 name=lan,bridge=vmbr${LAN_BRIDGE},firewall=1,ip=dhcp,type=veth \
|
||||||
--net1 name=admin,bridge=vmbr${ADMIN_BRIDGE},firewall=1,ip=dhcp,type=veth \
|
--net1 name=admin,bridge=vmbr${ADMIN_BRIDGE},firewall=1,ip=dhcp,type=veth \
|
||||||
|
--net2 name=wan,bridge=vmbr${WAN_BRIDGE},firewall=1${WAN_SSH_IP:+,ip=${WAN_SSH_IP}},type=veth \
|
||||||
--storage local-lvm \
|
--storage local-lvm \
|
||||||
--rootfs local-lvm:$DRIVE \
|
--rootfs local-lvm:$DRIVE \
|
||||||
--unprivileged 1 \
|
--unprivileged 1 \
|
||||||
|
|||||||
@ -52,13 +52,16 @@ xread "Wireguard endpoint port: " ENDPOINT_PORT
|
|||||||
CLIENT_IPS=${CLIENT_IPS:-10.42.0.0/16}
|
CLIENT_IPS=${CLIENT_IPS:-10.42.0.0/16}
|
||||||
ALLOWED_IPS=${ALLOWED_IPS:-0.0.0.0/0,${CLIENT_IPS}}
|
ALLOWED_IPS=${ALLOWED_IPS:-0.0.0.0/0,${CLIENT_IPS}}
|
||||||
|
|
||||||
|
DNS=${DNS:-${NS_LAN_IP:-${DFL_NS_LAN_IP}}}
|
||||||
|
DNS=${DNS/\/*}
|
||||||
|
xread "Local network DNS:" DNS
|
||||||
|
|
||||||
xreadYes "Show profile as QRcode when done?" QRCODE
|
xreadYes "Show profile as QRcode when done?" QRCODE
|
||||||
|
QRCODE=${QRCODE:-0}
|
||||||
|
|
||||||
readVars
|
readVars
|
||||||
|
|
||||||
|
|
||||||
DNS=${NS_LAN_IP/\/*}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#----------------------------------------------------------------------
|
#----------------------------------------------------------------------
|
||||||
@ -103,19 +106,10 @@ echo "# Copying assets..."
|
|||||||
echo "# Setup: wireguard default profile..."
|
echo "# Setup: wireguard default profile..."
|
||||||
@ lxc-attach $ID -- bash -c "cd /root \
|
@ lxc-attach $ID -- bash -c "cd /root \
|
||||||
&& QRCODE=${QRCODE} make default.client"
|
&& QRCODE=${QRCODE} make default.client"
|
||||||
@ lxc-attach $ID -- chmod 600 /etc/wireguard/wg0.conf
|
|
||||||
|
|
||||||
echo "# client config:"
|
echo "# client config:"
|
||||||
@ mkdir -p clients
|
@ mkdir -p clients
|
||||||
@ pct pull $ID /etc/wireguard/clients/default.conf clients/default.conf
|
@ pct pull $ID /etc/wireguard/clients/default.conf clients/default.conf
|
||||||
# show the profile as a qrcode...
|
|
||||||
#if [ "$QRCODE" ] ; then
|
|
||||||
# echo "# default profile:"
|
|
||||||
# @ lxc-attach $ID -- qrencode -t UTF8 -r /etc/wireguard/clients/default.conf
|
|
||||||
#fi
|
|
||||||
|
|
||||||
#echo "# Setup: bridge device..."
|
|
||||||
@ lxc-attach $ID wg-quick up wg0
|
|
||||||
|
|
||||||
echo "# Post config..."
|
echo "# Post config..."
|
||||||
pctSet $ID "${OPTS_STAGE_2}" $REBOOT
|
pctSet $ID "${OPTS_STAGE_2}" $REBOOT
|
||||||
|
|||||||
@ -1,10 +1,10 @@
|
|||||||
|
|
||||||
|
INTERFACE := wg0
|
||||||
|
|
||||||
SERVER_DIR := /etc/wireguard/
|
SERVER_DIR := /etc/wireguard/
|
||||||
SERVER_TPL := templates/wg0.conf
|
SERVER_TPL := templates/server.conf
|
||||||
SERVER_CLIENT_TPL := templates/wg0-client.tpl
|
SERVER_CLIENT_TPL := templates/client.tpl
|
||||||
SERVER_CONF := $(SERVER_DIR)/wg0.conf
|
SERVER_CONF := $(SERVER_DIR)/$(INTERFACE).conf
|
||||||
SERVER_KEY := $(SERVER_DIR)/server_id
|
SERVER_KEY := $(SERVER_DIR)/server_id
|
||||||
SERVER_PUBLIC_KEY := $(SERVER_DIR)/server_id.pub
|
SERVER_PUBLIC_KEY := $(SERVER_DIR)/server_id.pub
|
||||||
|
|
||||||
@ -26,6 +26,7 @@ ALLOWED_IPS ?= ${ALLOWED_IPS}
|
|||||||
wg genkey 2> /dev/null > $@
|
wg genkey 2> /dev/null > $@
|
||||||
chmod 600 $@
|
chmod 600 $@
|
||||||
|
|
||||||
|
|
||||||
%_id.pub: %_id
|
%_id.pub: %_id
|
||||||
cat $< | wg pubkey > $@
|
cat $< | wg pubkey > $@
|
||||||
|
|
||||||
@ -39,6 +40,9 @@ $(SERVER_CONF): $(SERVER_TPL) $(SERVER_KEY)
|
|||||||
-e 's/\$${\CLIENT_IPS}/$(subst /,\/,$(CLIENT_IPS))/g' \
|
-e 's/\$${\CLIENT_IPS}/$(subst /,\/,$(CLIENT_IPS))/g' \
|
||||||
-e 's/\$${\SERVER_PRIVATE_KEY}/'$$(sed -e 's/\//\\\//g' "$(SERVER_KEY)")'/g' \
|
-e 's/\$${\SERVER_PRIVATE_KEY}/'$$(sed -e 's/\//\\\//g' "$(SERVER_KEY)")'/g' \
|
||||||
> "$@"
|
> "$@"
|
||||||
|
chmod 600 $@
|
||||||
|
wg-quick up $(INTERFACE)
|
||||||
|
|
||||||
|
|
||||||
# XXX need to figure out a way to link this to the .config file without
|
# XXX need to figure out a way to link this to the .config file without
|
||||||
# conflicting with the server's wg0.conf
|
# conflicting with the server's wg0.conf
|
||||||
@ -64,15 +68,19 @@ $(SERVER_CONF): $(SERVER_TPL) $(SERVER_KEY)
|
|||||||
-e 's/\$${\CLIENT_PUBLIC_KEY}/'$$(sed -e 's/\//\\\//g' "$(CLIENT_DIR)/$*_id.pub")'/g' \
|
-e 's/\$${\CLIENT_PUBLIC_KEY}/'$$(sed -e 's/\//\\\//g' "$(CLIENT_DIR)/$*_id.pub")'/g' \
|
||||||
-e 's/\$${\SERVER_PUBLIC_KEY}/'$$(sed -e 's/\//\\\//g' "$(SERVER_PUBLIC_KEY)")'/g' \
|
-e 's/\$${\SERVER_PUBLIC_KEY}/'$$(sed -e 's/\//\\\//g' "$(SERVER_PUBLIC_KEY)")'/g' \
|
||||||
>> "$(SERVER_CONF)"
|
>> "$(SERVER_CONF)"
|
||||||
@ [ -z "$$QRCODE" ] \
|
make update $*.show
|
||||||
|| ( echo "# Profile: $*" \
|
|
||||||
|
|
||||||
|
%.show: $(CLIENT_DIR)/%.conf
|
||||||
|
@ [ "$(QRCODE)" == "1" ] \
|
||||||
|
&& ( echo "# Profile: $*" \
|
||||||
&& qrencode -t UTF8 -r "$(CLIENT_DIR)/$*.conf" )
|
&& qrencode -t UTF8 -r "$(CLIENT_DIR)/$*.conf" )
|
||||||
|
@ cat "$(CLIENT_DIR)/$*.conf"
|
||||||
|
@ echo
|
||||||
|
|
||||||
|
|
||||||
|
update:
|
||||||
%.qr: %.client
|
wg syncconf $(INTERFACE) <(wg-quick strip $(INTERFACE))
|
||||||
@ ( echo "# Profile: $*" \
|
|
||||||
&& qrencode -t UTF8 -r "$*.conf" )
|
|
||||||
|
|
||||||
|
|
||||||
server: $(SERVER_CONF)
|
server: $(SERVER_CONF)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user