2024-01-09 03:21:36 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2024-01-09 14:05:06 +03:00
|
|
|
SERVER_DIR := /etc/wireguard/
|
2024-01-09 03:21:36 +03:00
|
|
|
SERVER_TPL := templates/wg0.conf
|
|
|
|
|
SERVER_CLIENT_TPL := templates/wg0-client.conf
|
2024-01-09 14:05:06 +03:00
|
|
|
SERVER_CONF := $(SERVER_DIR)/wg0.conf
|
|
|
|
|
SERVER_KEY := $(SERVER_DIR)/server_id
|
|
|
|
|
SERVER_PUBLIC_KEY := $(SERVER_DIR)/server_id.pub
|
2024-01-09 03:21:36 +03:00
|
|
|
|
|
|
|
|
CLIENT_TPL := templates/client.conf
|
2024-01-09 14:05:06 +03:00
|
|
|
CLIENT_DIR := $(SERVER_DIR)/clients/
|
2024-01-09 03:21:36 +03:00
|
|
|
|
|
|
|
|
ENDPOINT_PORT := 51820
|
|
|
|
|
ENDPOINT :=
|
|
|
|
|
CLIENT_IPS := 10.42.0.0/16
|
|
|
|
|
DNS := 10.1.1.1
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%_id:
|
2024-01-09 14:05:06 +03:00
|
|
|
@ mkdir -p $$(dirname $@)
|
2024-01-09 03:21:36 +03:00
|
|
|
wg genkey > $@
|
|
|
|
|
|
|
|
|
|
%_id.pub: %_id
|
|
|
|
|
cat $< | wg pubkey > $@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$(SERVER_CONF): $(SERVER_TPL) $(SERVER_KEY)
|
|
|
|
|
cat $< \
|
|
|
|
|
| sed \
|
2024-01-09 14:31:04 +03:00
|
|
|
-e 's/\$${ENDPOINT_PORT}/$(SERVER_PORT)/g' \
|
|
|
|
|
-e 's/\$${CLIENT_IPS}/$(subst /,\/,$(CLIENT_IPS))/g' \
|
2024-01-09 14:34:48 +03:00
|
|
|
-e 's/\$${SERVER_PRIVATE_KEY}/'$$(cat "$(SERVER_KEY)" | sed -e 's/\//\\\//')'/g' \
|
2024-01-09 03:21:36 +03:00
|
|
|
> "$@"
|
|
|
|
|
|
|
|
|
|
$(CLIENT_DIR)/%.conf: $(CLIENT_TPL) $(SERVER_CLIENT_TPL) \
|
|
|
|
|
$(CLIENT_DIR)/%_id $(CLIENT_DIR)/%_id.pub \
|
|
|
|
|
$(SERVER_CONF) $(SERVER_PUBLIC_KEY)
|
2024-01-09 14:05:06 +03:00
|
|
|
@ mkdir -p $$(dirname $@)
|
2024-01-09 03:21:36 +03:00
|
|
|
cat "$<" \
|
|
|
|
|
| sed \
|
2024-01-09 14:31:04 +03:00
|
|
|
-e 's/\$${DNS}/$(DNS)/g' \
|
|
|
|
|
-e 's/\$${ENDPOINT}/$(ENDPOINT)/g' \
|
|
|
|
|
-e 's/\$${ENDPOINT_PORT}/$(ENDPOINT_PORT)/g' \
|
|
|
|
|
-e 's/\$${ALLOWED_IPS}/$(subst /,\/,$(ALLOWED_IPS))/g' \
|
|
|
|
|
-e 's/\$${CLIENT_IP}/$(subst /,\/,$(CLIENT_IP))/g' \
|
2024-01-09 14:34:48 +03:00
|
|
|
-e 's/\$${CLIENT_PRIVATE_KEY}/'$$(cat "$(CLIENT_DIR)/$%_id" | sed -e 's/\//\\\//')'/g' \
|
|
|
|
|
-e 's/\$${SERVER_PUBLIC_KEY}/'$$(cat "$(SERVER_PUBLIC_KEY)" | sed -e 's/\//\\\//')'/g' \
|
2024-01-09 03:21:36 +03:00
|
|
|
> "$@"
|
|
|
|
|
cat "$(SERVER_CLIENT_TPL)" \
|
|
|
|
|
| sed \
|
2024-01-09 14:31:04 +03:00
|
|
|
-e 's/\$${CLIENT_IP}/$(subst /,\/,$(CLIENT_IP))/g' \
|
|
|
|
|
-e 's/\$${ENDPOINT}/$(ENDPOINT)/g' \
|
|
|
|
|
-e 's/\$${ENDPOINT_PORT}/$(ENDPOINT_PORT)/g' \
|
2024-01-09 14:34:48 +03:00
|
|
|
-e 's/\$${CLIENT_PUBLIC_KEY}/'$$(cat "$(CLIENT_DIR)/$%_id.pub" | sed -e 's/\//\\\//')'/g' \
|
|
|
|
|
-e 's/\$${SERVER_PUBLIC_KEY}/'$$(cat "$(SERVER_PUBLIC_KEY)" | sed -e 's/\//\\\//')'/g' \
|
2024-01-09 03:21:36 +03:00
|
|
|
>> "$(SERVER_CONF)"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
server: $(SERVER_CONF)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
clients:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|