|  | 2 years ago | |
|---|---|---|
| .github | 2 years ago | |
| config | 2 years ago | |
| database | 2 years ago | |
| logger | 2 years ago | |
| media | 2 years ago | |
| sub | 2 years ago | |
| util | 2 years ago | |
| v2ui | 2 years ago | |
| web | 2 years ago | |
| xray | 2 years ago | |
| .gitignore | 2 years ago | |
| DockerInit.sh | 2 years ago | |
| Dockerfile | 2 years ago | |
| LICENSE | 2 years ago | |
| README.md | 2 years ago | |
| docker-compose.yml | 2 years ago | |
| go.mod | 2 years ago | |
| go.sum | 2 years ago | |
| install.sh | 2 years ago | |
| main.go | 2 years ago | |
| x-ui.service | 2 years ago | |
| x-ui.sh | 2 years ago | 
Disclaimer: This project is only for personal learning and communication, please do not use it for illegal purposes, please do not use it in a production environment
3x-ui panel supporting multi-protocol, Multi-lang (English,Farsi,Chinese,Russian)
If you think this project is helpful to you, you may wish to give a :star2:
Buy Me a Coffee :
TXncxkvhkDWGts487Pjqq1qT9JmwRUz8CCbash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh)
To install your desired version you can add the version to the end of install command. Example for ver v1.6.0:
bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) v1.6.0
apt-get install certbot -y
certbot certonly --standalone --agree-tos --register-unsafely-without-email -d yourdomain.com
certbot renew --dry-run
or you can use x-ui menu then number '16' (Apply for an SSL Certificate)
Before you set ssl on settings
After you set ssl on settings
| Variable | Type | Default | 
|---|---|---|
| XUI_LOG_LEVEL | "debug"|"info"|"warn"|"error" | "info" | 
| XUI_DEBUG | boolean | false | 
| XUI_BIN_FOLDER | string | "bin" | 
| XUI_DB_FOLDER | string | "/etc/x-ui" | 
Example:
XUI_BIN_FOLDER="bin" XUI_DB_FOLDER="/etc/x-ui" go build main.go
Install Docker:
bash <(curl -sSL https://get.docker.com)
Run 3x-ui:
docker compose up -d
OR
   docker run -itd \
      -e XRAY_VMESS_AEAD_FORCED=false \
      -v $PWD/db/:/etc/x-ui/ \
      -v $PWD/cert/:/root/cert/ \
      --network=host \
      --restart=unless-stopped \
      --name 3x-ui \
      ghcr.io/mhsanaei/3x-ui:latest
copy and paste to xray Configuration : (you don't need to do this if you have a fresh install)
If you want to use routing to WARP follow steps as below:
If you already installed warp, you can uninstall using below command:
warp u
Install WARP on socks proxy mode:
curl -fsSL https://gist.githubusercontent.com/hamid-gh98/dc5dd9b0cc5b0412af927b1ccdb294c7/raw/install_warp_proxy.sh | bash
Turn on the config you need in panel or Copy and paste this file to Xray Configuration
Config Features:
X-UI supports daily traffic notification, panel login reminder and other functions through the Tg robot. To use the Tg robot, you need to apply for the specific application tutorial. You can refer to the blog Set the robot-related parameters in the panel background, including:
Reference syntax:
/login with PUSH user data: {username: '', password: ''} for login/panel/api/inbounds base for following actions:| Method | Path | Action | 
|---|---|---|
| GET | "/list" | Get all inbounds | 
| GET | "/get/:id" | Get inbound with inbound.id | 
| GET | "/getClientTraffics/:email" | Get Client Traffics with email | 
| GET | "/createbackup" | Telegram bot sends backup to admins | 
| POST | "/add" | Add inbound | 
| POST | "/del/:id" | Delete Inbound | 
| POST | "/update/:id" | Update Inbound | 
| POST | "/clientIps/:email" | Client Ip address | 
| POST | "/clearClientIps/:email" | Clear Client Ip address | 
| POST | "/addClient" | Add Client to inbound | 
| POST | "/:id/delClient/:clientId" | Delete Client by clientId* | 
| POST | "/updateClient/:clientId" | Update Client by clientId* | 
| POST | "/:id/resetClientTraffic/:email" | Reset Client's Traffic | 
| POST | "/resetAllTraffics" | Reset traffics of all inbounds | 
| POST | "/resetAllClientTraffics/:id" | Reset traffics of all clients in an inbound | 
| POST | "/delDepletedClients/:id" | Delete inbound depleted clients (-1: all) | 
*- The field clientId should be filled by:
client.id for VMESS and VLESSclient.password for TROJANclient.email for Shadowsocks