2022-11-08 12:02:19 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
|
|
set -e
|
2022-11-07 09:23:30 +00:00
|
|
|
|
|
|
|
|
EVENT="{{ event_name }}"
|
2024-02-12 05:48:01 +00:00
|
|
|
AWG_MANAGER="/etc/amnezia/amneziawg/awg-manager.sh"
|
2022-11-08 12:02:19 +00:00
|
|
|
SESSION_ID="{{ user.gen_session.id }}"
|
2023-01-24 18:14:00 +00:00
|
|
|
API_URL="{{ config.api.url }}"
|
2024-02-12 05:48:01 +00:00
|
|
|
CURL="curl"
|
2022-11-08 12:02:19 +00:00
|
|
|
|
|
|
|
|
echo "EVENT=$EVENT"
|
2022-11-07 09:23:30 +00:00
|
|
|
|
|
|
|
|
case $EVENT in
|
|
|
|
|
INIT)
|
|
|
|
|
SERVER_HOST="{{ server.settings.host_name }}"
|
2022-08-31 15:36:12 +00:00
|
|
|
SERVER_INTERFACE="{{ server.settings.host_interface }}"
|
2024-02-12 05:48:01 +00:00
|
|
|
if [[ -z "$SERVER_INTERFACE" ]]; then
|
|
|
|
|
SERVER_INTERFACE=$(ip route | awk '/default/ {print $5; exit}')
|
|
|
|
|
fi
|
2022-11-07 09:23:30 +00:00
|
|
|
if [ -z $SERVER_HOST ]; then
|
2024-02-12 05:48:01 +00:00
|
|
|
SERVER_HOST="{{ server.settings.host }}"
|
2022-11-07 09:23:30 +00:00
|
|
|
fi
|
2023-05-15 06:52:16 +00:00
|
|
|
|
2023-02-10 13:27:08 +00:00
|
|
|
echo "Install required packages"
|
2022-11-07 09:23:30 +00:00
|
|
|
apt update
|
|
|
|
|
apt install -y \
|
2022-12-13 18:14:41 +00:00
|
|
|
iproute2 \
|
|
|
|
|
iptables \
|
2023-05-15 06:52:16 +00:00
|
|
|
curl \
|
2024-02-12 05:48:01 +00:00
|
|
|
wget \
|
|
|
|
|
git \
|
|
|
|
|
build-essential \
|
|
|
|
|
make
|
2023-05-15 06:52:16 +00:00
|
|
|
|
|
|
|
|
echo "Check domain: $API_URL"
|
|
|
|
|
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" $API_URL/shm/v1/test)
|
|
|
|
|
if [ $HTTP_CODE -ne '200' ]; then
|
|
|
|
|
echo "ERROR: incorrect API URL: $API_URL"
|
|
|
|
|
echo "Got status: $HTTP_CODE"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2024-02-12 05:48:01 +00:00
|
|
|
mkdir -p /opt/go
|
|
|
|
|
cd /opt/go
|
|
|
|
|
wget https://go.dev/dl/go1.22.0.linux-amd64.tar.gz
|
|
|
|
|
rm -rf /usr/local/go && tar -C /usr/local -xzf go1.22.0.linux-amd64.tar.gz
|
|
|
|
|
echo "export PATH=$PATH:/usr/local/go/bin" >> /etc/profile
|
|
|
|
|
source $HOME/.profile
|
|
|
|
|
if ! command -v go &> /dev/null; then
|
|
|
|
|
cp /usr/local/go/bin/go /usr/bin && cp /usr/local/go/bin/gofmt /usr/bin
|
2022-11-08 12:02:19 +00:00
|
|
|
fi
|
|
|
|
|
|
2024-02-12 05:48:01 +00:00
|
|
|
git clone https://github.com/amnezia-vpn/amneziawg-go.git /opt/amnezia-go
|
|
|
|
|
cd /opt/amnezia-go
|
|
|
|
|
make
|
|
|
|
|
sleep 1
|
|
|
|
|
cp /opt/amnezia-go/amneziawg-go /usr/bin
|
|
|
|
|
|
|
|
|
|
git clone https://github.com/amnezia-vpn/amneziawg-tools.git /opt/amnezia-tools
|
|
|
|
|
cd /opt/amnezia-tools/src
|
|
|
|
|
make
|
|
|
|
|
make install
|
|
|
|
|
sleep 1
|
|
|
|
|
|
|
|
|
|
echo "Download awg-manager.sh"
|
2022-11-07 09:23:30 +00:00
|
|
|
cd /etc/wireguard
|
2024-02-12 05:48:01 +00:00
|
|
|
$CURL -s https://raw.githubusercontent.com/bkeenke/awg-manager/master/awg-manager.sh > $AWG_MANAGER
|
2023-02-10 13:27:08 +00:00
|
|
|
|
|
|
|
|
echo "Init server"
|
2024-02-12 05:48:01 +00:00
|
|
|
chmod 700 $AWG_MANAGER
|
2022-08-31 15:36:12 +00:00
|
|
|
if [ $SERVER_INTERFACE ]; then
|
2024-02-12 05:48:01 +00:00
|
|
|
$AWG_MANAGER -i -s $SERVER_HOST -I $SERVER_INTERFACE
|
2022-08-31 15:36:12 +00:00
|
|
|
else
|
2024-02-12 05:48:01 +00:00
|
|
|
$AWG_MANAGER -i -s $SERVER_HOST
|
2022-08-31 15:36:12 +00:00
|
|
|
fi
|
2022-11-07 09:23:30 +00:00
|
|
|
;;
|
|
|
|
|
CREATE)
|
2023-02-10 13:27:08 +00:00
|
|
|
echo "Create new user"
|
2024-02-12 05:48:01 +00:00
|
|
|
USER_CFG=$($AWG_MANAGER -u "{{ us.id }}" -c -p)
|
2022-11-07 09:23:30 +00:00
|
|
|
|
2023-02-10 13:27:08 +00:00
|
|
|
echo "Upload user key to SHM"
|
2024-02-12 05:48:01 +00:00
|
|
|
$CURL -s -XPUT \
|
2022-11-07 09:23:30 +00:00
|
|
|
-H "session-id: $SESSION_ID" \
|
|
|
|
|
-H "Content-Type: text/plain" \
|
2023-01-24 18:14:00 +00:00
|
|
|
$API_URL/shm/v1/storage/manage/vpn{{ us.id }} \
|
2022-11-08 12:54:29 +00:00
|
|
|
--data-binary "$USER_CFG"
|
2022-11-08 12:02:19 +00:00
|
|
|
echo "done"
|
|
|
|
|
;;
|
|
|
|
|
ACTIVATE)
|
2023-02-10 13:27:08 +00:00
|
|
|
echo "Activate user"
|
2024-02-12 05:48:01 +00:00
|
|
|
$AWG_MANAGER -u "{{ us.id }}" -U
|
2022-11-08 12:02:19 +00:00
|
|
|
echo "done"
|
|
|
|
|
;;
|
|
|
|
|
BLOCK)
|
2023-02-10 13:27:08 +00:00
|
|
|
echo "Block user"
|
2024-02-12 05:48:01 +00:00
|
|
|
$AWG_MANAGER -u "{{ us.id }}" -L
|
2022-11-07 09:23:30 +00:00
|
|
|
echo "done"
|
|
|
|
|
;;
|
|
|
|
|
REMOVE)
|
2023-02-10 13:27:08 +00:00
|
|
|
echo "Remove user"
|
2024-02-12 05:48:01 +00:00
|
|
|
$AWG_MANAGER -u "{{ us.id }}" -d
|
2023-02-10 13:27:08 +00:00
|
|
|
|
|
|
|
|
echo "Remove user key from SHM"
|
2024-02-12 05:48:01 +00:00
|
|
|
$CURL -s -XDELETE \
|
2022-11-08 12:02:19 +00:00
|
|
|
-H "session-id: $SESSION_ID" \
|
2023-01-24 18:14:00 +00:00
|
|
|
$API_URL/shm/v1/storage/manage/vpn{{ us.id }}
|
2022-11-07 09:23:30 +00:00
|
|
|
echo "done"
|
|
|
|
|
;;
|
|
|
|
|
*)
|
|
|
|
|
echo "Unknown event: $EVENT. Exit."
|
|
|
|
|
exit 0
|
|
|
|
|
;;
|
|
|
|
|
esac
|