add-wg.sh 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. #!/bin/bash
  2. red='\e[1;31m'
  3. green='\e[0;32m'
  4. NC='\e[0m'
  5. MYIP=$(wget -qO- ifconfig.me/ip);
  6. # Load params
  7. source /etc/wireguard/params
  8. source /var/lib/premium-script/ipvps.conf
  9. if [[ "$IP" = "" ]]; then
  10. SERVER_PUB_IP=$(wget -qO- ifconfig.me/ip);
  11. else
  12. SERVER_PUB_IP=$IP
  13. fi
  14. echo ""
  15. echo "Tell me a name for the client."
  16. echo "Use one word only, no special characters."
  17. until [[ ${CLIENT_NAME} =~ ^[a-zA-Z0-9_]+$ && ${CLIENT_EXISTS} == '0' ]]; do
  18. read -rp "Client name: " -e CLIENT_NAME
  19. CLIENT_EXISTS=$(grep -w $CLIENT_NAME /etc/wireguard/wg0.conf | wc -l)
  20. if [[ ${CLIENT_EXISTS} == '1' ]]; then
  21. echo ""
  22. echo "A client with the specified name was already created, please choose another name."
  23. exit 1
  24. fi
  25. done
  26. echo "IPv4 Detected"
  27. ENDPOINT="$SERVER_PUB_IP:$SERVER_PORT"
  28. WG_CONFIG="/etc/wireguard/wg0.conf"
  29. LASTIP=$( grep "/32" $WG_CONFIG | tail -n1 | awk '{print $3}' | cut -d "/" -f 1 | cut -d "." -f 4 )
  30. if [[ "$LASTIP" = "" ]]; then
  31. CLIENT_ADDRESS="10.66.66.2"
  32. else
  33. CLIENT_ADDRESS="10.66.66.$((LASTIP+1))"
  34. fi
  35. # Adguard DNS by default
  36. CLIENT_DNS_1="176.103.130.130"
  37. CLIENT_DNS_2="176.103.130.131"
  38. MYIP=$(wget -qO- ifconfig.me/ip);
  39. read -p "Expired (days): " masaaktif
  40. exp=`date -d "$masaaktif days" +"%Y-%m-%d"`
  41. # Generate key pair for the client
  42. CLIENT_PRIV_KEY=$(wg genkey)
  43. CLIENT_PUB_KEY=$(echo "$CLIENT_PRIV_KEY" | wg pubkey)
  44. CLIENT_PRE_SHARED_KEY=$(wg genpsk)
  45. # Create client file and add the server as a peer
  46. echo "[Interface]
  47. PrivateKey = $CLIENT_PRIV_KEY
  48. Address = $CLIENT_ADDRESS/24
  49. DNS = $CLIENT_DNS_1,$CLIENT_DNS_2
  50. [Peer]
  51. PublicKey = $SERVER_PUB_KEY
  52. PresharedKey = $CLIENT_PRE_SHARED_KEY
  53. Endpoint = $ENDPOINT
  54. AllowedIPs = 0.0.0.0/0,::/0" >>"$HOME/$SERVER_WG_NIC-client-$CLIENT_NAME.conf"
  55. # Add the client as a peer to the server
  56. echo -e "### Client $CLIENT_NAME $exp
  57. [Peer]
  58. PublicKey = $CLIENT_PUB_KEY
  59. PresharedKey = $CLIENT_PRE_SHARED_KEY
  60. AllowedIPs = $CLIENT_ADDRESS/32" >>"/etc/wireguard/$SERVER_WG_NIC.conf"
  61. systemctl restart "wg-quick@$SERVER_WG_NIC"
  62. cp $HOME/$SERVER_WG_NIC-client-$CLIENT_NAME.conf /home/vps/public_html/$CLIENT_NAME.conf
  63. clear
  64. sleep 0.5
  65. echo Generate PrivateKey
  66. sleep 0.5
  67. echo Generate PublicKey
  68. sleep 0.5
  69. echo Generate PresharedKey
  70. clear
  71. echo -e ""
  72. echo -e "==========-Wireguard-=========="
  73. echo -e "Wireguard : http://$MYIP:81/$CLIENT_NAME.conf"
  74. echo -e "==============================="
  75. echo -e "Expired On : $exp"
  76. rm -f /root/wg0-client-$CLIENT_NAME.conf