Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ghosts6/v2ray_openvpn_setup
in this repo we will setup v2ray server , openvpn server and Squid on linux machine(debian)
https://github.com/ghosts6/v2ray_openvpn_setup
apache bash linux nginx open-vpn squid v2ray
Last synced: about 6 hours ago
JSON representation
in this repo we will setup v2ray server , openvpn server and Squid on linux machine(debian)
- Host: GitHub
- URL: https://github.com/ghosts6/v2ray_openvpn_setup
- Owner: Ghosts6
- Created: 2024-02-29T20:32:11.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-03-14T10:50:30.000Z (10 months ago)
- Last Synced: 2024-11-15T14:07:49.381Z (2 months ago)
- Topics: apache, bash, linux, nginx, open-vpn, squid, v2ray
- Language: Shell
- Homepage:
- Size: 173 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
![baner](https://github.com/Ghosts6/Local-website/blob/main/img/Baner.png)
# 🌎v2ray,openvpn&squid:
This repo include bash files to setup and manage service like v2ray and openvpn
in this repo we place two setup method and some scripts which you can use them for service
management,also you can use squid.sh to setup proxy server.# đź“–usage:
To using this files, clone the repository using the command: git clone https://github.com/Ghosts6/v2ray_openvpn_setup.git. Ensure executable permissions by running chmod +x filename on the relevant file. Depending on your requirements, execute the desired file by running ./filename. This sequence allows seamless access and execution of the provided files from the repository.
```bash
chmod +x start.sh stop.sh setup.sh status.sh optimize.sh manual_setup.sh
./example.sh
```# 📱setup.sh:
With setup.sh, you can easily configure V2Ray, OpenVPN, or both at same time. The script automates the preparation of requirements, configures the necessary firewall rules during setup, and setup will be end by entering some input such as domain, preferred services, and more, streamlining the service setup process.
setup.sh:
```bash
#!/bin/bashecho "Updating software..."
sudo apt-get update && sudo apt-get upgrade -y && sudo apt-get autoremove -yecho "Enabling IP forwarding..."
sudo sysctl -w net.ipv4.ip_forward=1
sudo sysctl -pecho "Installing firewall..."
sudo apt-get install ufwecho "Writing firewall rules and enabling firewall...."
sudo ufw allow ssh
sudo ufw allow http
sudo ufw allow https
sudo ufw allow 1000/tcp
sudo ufw allow 443/tcp
sudo ufw allow 1194/udpsudo ufw enable
echo "Which service do you like to install?"
echo "1. v2ray"
echo "2. openvpnserver"
echo "3. both"read -p "Enter the number corresponding to your choice: " choice
case $choice in
1)
echo "Installing v2ray..."
sudo apt-get install nginx -y
sudo apt-get install wgetread -p "Please enter your domain (example.com): " domain
sudo sed -i "s/server_name _;/server_name $domain;/g" /etc/nginx/sites-available/default
systemctl restart nginx
snap install core
snap install --classic certbot
ln -s /snap/bin/certbot /usr/bin/certbot
echo "nginx configuration:"
certbot --nginx
echo "v2ray setup..."
wget --no-check-certificate https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh
bash install-release.sh
sudo apt-get install uuid -y
uuid=$(uuid -v 4)
hex_number=$(openssl rand -hex 4)
config_file="/usr/local/etc/v2ray/config.json"
echo "{
\"log\": {
\"loglevel\": \"warning\",
\"access\": \"/var/log/v2ray/access.log\",
\"error\": \"/var/log/v2ray/error.log\"
},
\"inbounds\": [{
\"port\": 10000,
\"protocol\": \"vmess\",
\"settings\": {
\"clients\": [
{
\"id\": \"$uuid\",
\"level\": 1,
\"alterId\": 4
}
]
},
\"streamSettings\": {
\"network\": \"ws\",
\"wsSettings\": {
\"path\": \"$hex_number\"
}
}
}],
\"outbounds\": [{
\"protocol\": \"socks\",
\"settings\": {
\"servers\": [{
\"address\": \"127.0.0.1\",
\"port\": 9050,
\"auth\": \"noauth\"
}]
}
},{
\"protocol\": \"blackhole\",
\"settings\": {},
\"tag\": \"blocked\"
}],
\"routing\": {
\"rules\": [
{
\"type\": \"field\",
\"ip\": [\"geoip:private\"],
\"outboundTag\": \"blocked\"
}
]
}
}" | sudo tee "$config_file" > /dev/null# nginx config
cat < /dev/null
location /144c0889 {
proxy_redirect off;
proxy_pass http://127.0.0.1:10000;
proxy_http_version 1.1;
proxy_set_header Upgrade \$http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host \$http_host;
# Show real IP if you enable V2Ray access log
proxy_set_header X-Real-IP \$remote_addr;
proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;
}
EOL
systemctl enable v2ray
systemctl start v2ray
;;2)
echo "Installing openvpnserver..."
echo "Your IP is ...."
sudo apt-get install curl && sudo apt-get install wget
curl ifconfig.me || wget -qO- ifconfig.me
wget https://git.io/vpn -O openvpn-install.sh
sudo chmod +x openvpn-install.sh
echo "Please fill in data based on your need..."
sudo bash openvpn-install.sh
sudo systemctl start [email protected]read -p "Do you want to create a new client for OpenVPN? (y/n): " answer_openvpn
if [[ "$answer_openvpn" == "y" || "$answer_openvpn" == "Y" ]]; then
sudo bash openvpn-install.sh
else
echo "OpenVPN installation completed."
fi
;;
3)
echo "Installing both v2ray and openvpnserver..."
# Install v2ray (case 1)
echo "Installing v2ray..."
sudo apt-get install nginx -y
sudo apt-get install wgetread -p "Please enter your domain (example.com): " domain
sudo sed -i "s/server_name _;/server_name $domain;/g" /etc/nginx/sites-available/default
systemctl restart nginx
snap install core
snap install --classic certbot
ln -s /snap/bin/certbot /usr/bin/certbot
echo "nginx configuration:"
certbot --nginx
echo "v2ray setup..."
wget --no-check-certificate https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh
bash install-release.sh
sudo apt-get install uuid -y
uuid=$(uuid -v 4)
hex_number=$(openssl rand -hex 4)
config_file="/usr/local/etc/v2ray/config.json"
echo "{
\"log\": {
\"loglevel\": \"warning\",
\"access\": \"/var/log/v2ray/access.log\",
\"error\": \"/var/log/v2ray/error.log\"
},
\"inbounds\": [{
\"port\": 10000,
\"protocol\": \"vmess\",
\"settings\": {
\"clients\": [
{
\"id\": \"$uuid\",
\"level\": 1,
\"alterId\": 4
}
]
},
\"streamSettings\": {
\"network\": \"ws\",
\"wsSettings\": {
\"path\": \"$hex_number\"
}
}
}],
\"outbounds\": [{
\"protocol\": \"socks\",
\"settings\": {
\"servers\": [{
\"address\": \"127.0.0.1\",
\"port\": 9050,
\"auth\": \"noauth\"
}]
}
},{
\"protocol\": \"blackhole\",
\"settings\": {},
\"tag\": \"blocked\"
}],
\"routing\": {
\"rules\": [
{
\"type\": \"field\",
\"ip\": [\"geoip:private\"],
\"outboundTag\": \"blocked\"
}
]
}
}" | sudo tee "$config_file" > /dev/null# nginx config
cat < /dev/null
location /144c0889 {
proxy_redirect off;
proxy_pass http://127.0.0.1:10000;
proxy_http_version 1.1;
proxy_set_header Upgrade \$http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host \$http_host;
# Show real IP if you enable V2Ray access log
proxy_set_header X-Real-IP \$remote_addr;
proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;
}
EOL
systemctl enable v2ray
systemctl start v2rayecho "Installing openvpnserver..."
echo "Your IP is ...."
sudo apt-get install curl && sudo apt-get install wget
curl ifconfig.me || wget -qO- ifconfig.me
wget https://git.io/vpn -O openvpn-install.sh
sudo chmod +x openvpn-install.sh
echo "Please fill in data based on your need..."
sudo bash openvpn-install.sh
sudo systemctl start [email protected]read -p "Do you want to create a new client for OpenVPN? (y/n): " answer_openvpn
if [[ "$answer_openvpn" == "y" || "$answer_openvpn" == "Y" ]]; then
sudo bash openvpn-install.sh
else
echo "OpenVPN installation completed."
fi
;;
*)
echo "Invalid choice. Exiting..."
exit 1
;;
esacecho "Installation completed."
```
# 🖥️manual_setup.sh:For pepole who seek configurability and accessibility, our manual_setup.sh script allows you to customize your services. Simply run
./manual_setup.sh to take full control of the configuration processmanual setup:
```bash
#!/bin/bashecho "Updating software..."
sudo apt-get update && sudo apt-get upgrade -y && sudo apt-get autoremove -yecho "Installing packages..."
sudo apt install -y openvpn v2ray squidecho "OpenVPN setup: Editing config file..."
sudo nano /etc/openvpn/server.confecho "Generate encryption keys..."
sudo openvpn --genkey --secret /etc/openvpn/ta.key
sudo openvpn --genkey --secret /etc/openvpn/ta.keyecho "Starting and enabling OpenVPN..."
sudo systemctl start openvpn@server && sudo systemctl enable openvpn@serverecho "Configuring IP forwarding..."
sudo sysctl -w net.ipv4.ip_forward=1
sudo sysctl -pecho "Adjusting Firewall Settings for OpenVPN..."
sudo ufw allow 1194/udp
sudo ufw reloadecho "V2Ray setup: Editing config file..."
sudo nano /etc/v2ray/config.jsonecho "Starting and enabling V2Ray..."
sudo systemctl start v2ray && sudo systemctl enable v2rayecho "Adjusting Firewall Settings for V2Ray..."
sudo ufw allow 12345
sudo ufw reloadecho "Script execution completed."
```# 📲squid
Proxy server ,for this purpose we use squid service to run over proxy server and for this work we can use squid.sh which will install requirment and setup proxy server and confige it, also with help of this script there is no need to config fire
wall other feature include automatic configuration and creating block list. squid.sh```bash
#!/bin/bashecho "update and upgrade..."
sudo apt-get update
sudo apt-get upgradeecho "installing squid..."
sudo apt-get install squid
sudo systemctl enable squidecho "configuretion..."
read -p "Enter port[3218]" port
if [ -z "$port" ]; then
port="3218"
fisudo sed -i "s/http_port 3128/http_port $port transparent/" /etc/squid/squid.conf
sudo sed -i "s/http_access deny all/http_access allow all/" /etc/squid/squid.confecho "config firewall..."
sudo ufw allow $port
sudo ufw reload
sudo ufw statusecho "starting service..."
sudo systemctl restart squid
sudo systemctl status squidecho "create user..."
sudo apt-get install apache2-utils -y
sudo touch /etc/squid/passwd
sudo chown proxy: /etc/squid/passwdread -p "Enter username:" user
sudo htpasswd /etc/squid/passwd $user# Adding lines for basic authentication
echo "auth_param basic program /usr/lib64/squid/basic_ncsa_auth /etc/squid/passwd" | sudo tee -a /etc/squid/squid.conf
echo "auth_param basic children 5" | sudo tee -a /etc/squid/squid.conf
echo "auth_param basic realm Squid Basic Authentication" | sudo tee -a /etc/squid/squid.conf
echo "auth_param basic credentialsttl 2 hours" | sudo tee -a /etc/squid/squid.conf
echo "acl auth_users proxy_auth REQUIRED" | sudo tee -a /etc/squid/squid.confread -p "installtion finshed,do you want create website block list(y/n)?" choice
if [[ "$choice" == 'y' || "$choice" == 'Y' ]]; then
read -p "Enter the number of websites you want to block (default value = 10): " rangeif [ -z "$range" ]; then
range=10
fiarray_name="block$range"
declare -a "$array_name"echo "Hint ! enter dot(.) befor start of url for example(.yahoo.com) "
# Get input for the array
for ((i=0; i<$range; i++)); do
read -p "Enter website URL for ${array_name}[$i]: " website
eval "${array_name}[$i]=$website"
done# Write array members to the file
for ((i=0; i<$range; i++)); do
echo "${array_name}[$i]" | sudo tee -a /etc/squid/blocked.acl
doneecho "acl blocked_websites dstdomain \"/etc/squid/blocked.acl\"" | sudo tee -a /etc/squid/squid.conf
echo "http_access deny blocked_websites" | sudo tee -a /etc/squid/squid.confsudo systemctl restart squid
sudo systemctl status squidecho "end of program"
else
echo "End of program."
fi
```# 🚀scripts:
We offer a suite of bash files to streamline service management. Use start.sh to initiate and enable services, stop.sh to halt services, status.sh to check service status, and optimize.sh to enhance performance. The optimization script updates packages, cleans cache, optimizes ports, and restarts services for an efficient system
# đź’»services:
When initiating services using the provided bash file, the selection of services and methods determines their launch configuration. If opting for the setup file, V2Ray starts on port 10000 with the configuration file at /usr/local/etc/v2ray/config.json, while Nginx begins on port 443, using the configuration file at /etc/nginx/sites-available/default. Opting for OpenVPN defaults to port 1194, with the option to customize during setup. The protocol, either UDP or TCP, can also be specified, with the configuration file located at /etc/openvpn/server/server.conf. For manual setup, users have full control over configurations, but it's crucial to configure the firewall settings post-setup.