Merge pull request #7 from serogaq/feature/6.subsHeadersAndBuildImageTar

6 / sub headers and build image tar on mac
This commit is contained in:
serogaq 2024-12-06 23:30:34 +03:00 committed by GitHub
commit 8f9e9de7c8
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 91 additions and 9 deletions

View file

@ -5,3 +5,6 @@ XUI_SERVER_IP=""
XUI_PANEL_DOMAIN=""
XUI_SUB_DOMAIN=""
XUI_VLESS_SNI=""
#XUI_SUB_PROFILE_TITLE=""
#XUI_SUB_SUPPORT_URL=""
#XUI_SUB_PROFILE_WEB_PAGE_URL=""

View file

@ -32,14 +32,18 @@ services:
- "traefik.tcp.routers.vless.service=3x-ui-inbound-443"
- "traefik.tcp.services.3x-ui-inbound-443.loadbalancer.server.port=443"
volumes:
- $PWD/db/:/etc/x-ui/
- $PWD/cert/:/root/cert/
- ./db/:/etc/x-ui/
- ./cert/:/root/cert/
- ./announce.txt:/etc/x-ui/announce.txt
environment:
PUID: 1000
PGID: 1000
XRAY_VMESS_AEAD_FORCED: "false"
TZ: Europe/Moscow
XUI_SERVER_IP: "${XUI_SERVER_IP}"
XUI_SUB_PROFILE_TITLE: "${XUI_SUB_PROFILE_TITLE:-}"
XUI_SUB_SUPPORT_URL: "${XUI_SUB_SUPPORT_URL:-}"
XUI_SUB_PROFILE_WEB_PAGE_URL: "${XUI_SUB_PROFILE_WEB_PAGE_URL:-}"
tty: true
restart: unless-stopped

View file

@ -4,6 +4,7 @@ import (
"encoding/base64"
"net"
"strings"
"io/ioutil"
"os"
"github.com/gin-gonic/gin"
@ -74,6 +75,23 @@ func (a *SUBController) subs(c *gin.Context) {
host = c.Request.Host
}
}
var profileTitle string
profileTitle = os.Getenv("XUI_SUB_PROFILE_TITLE")
if profileTitle == "" {
profileTitle = subId
}
var supportUrl string
supportUrl = os.Getenv("XUI_SUB_PROFILE_TITLE")
if supportUrl == "" {
supportUrl = os.Getenv("XUI_SUB_DOMAIN")
}
var profileWebPageUrl string
profileWebPageUrl = os.Getenv("XUI_SUB_PROFILE_WEB_PAGE_URL")
if profileWebPageUrl == "" {
profileWebPageUrl = os.Getenv("XUI_SUB_DOMAIN")
}
var announceText string
announceText = getAnnounceText()
subs, header, err := a.subService.GetSubs(subId, host)
if err != nil || len(subs) == 0 {
c.String(400, "Error!")
@ -86,7 +104,12 @@ func (a *SUBController) subs(c *gin.Context) {
// Add headers
c.Writer.Header().Set("Subscription-Userinfo", header)
c.Writer.Header().Set("Profile-Update-Interval", a.updateInterval)
c.Writer.Header().Set("Profile-Title", subId)
c.Writer.Header().Set("Profile-Title", profileTitle)
c.Writer.Header().Set("Support-Url", supportUrl)
c.Writer.Header().Set("Profile-Web-Page-Url", profileWebPageUrl)
if announceText != "" {
c.Writer.Header().Set("Announce", announceText)
}
if a.subEncrypt {
c.String(200, base64.StdEncoding.EncodeToString([]byte(result)))
@ -115,6 +138,23 @@ func (a *SUBController) subJsons(c *gin.Context) {
host = c.Request.Host
}
}
var profileTitle string
profileTitle = os.Getenv("XUI_SUB_PROFILE_TITLE")
if profileTitle == "" {
profileTitle = subId
}
var supportUrl string
supportUrl = os.Getenv("XUI_SUB_PROFILE_TITLE")
if supportUrl == "" {
supportUrl = os.Getenv("XUI_SUB_DOMAIN")
}
var profileWebPageUrl string
profileWebPageUrl = os.Getenv("XUI_SUB_PROFILE_WEB_PAGE_URL")
if profileWebPageUrl == "" {
profileWebPageUrl = os.Getenv("XUI_SUB_DOMAIN")
}
var announceText string
announceText = getAnnounceText()
jsonSub, header, err := a.subJsonService.GetJson(subId, host)
if err != nil || len(jsonSub) == 0 {
c.String(400, "Error!")
@ -123,12 +163,32 @@ func (a *SUBController) subJsons(c *gin.Context) {
// Add headers
c.Writer.Header().Set("Subscription-Userinfo", header)
c.Writer.Header().Set("Profile-Update-Interval", a.updateInterval)
c.Writer.Header().Set("Profile-Title", subId)
c.Writer.Header().Set("Profile-Title", profileTitle)
c.Writer.Header().Set("Support-Url", supportUrl)
c.Writer.Header().Set("Profile-Web-Page-Url", profileWebPageUrl)
if announceText != "" {
c.Writer.Header().Set("Announce", announceText)
}
c.String(200, jsonSub)
}
}
func getAnnounceText() (string) {
announceFilePath := "/etc/x-ui/announce.txt"
_, err := os.Stat(announceFilePath)
if os.IsNotExist(err) {
return ""
}
content, err := ioutil.ReadFile(announceFilePath)
if err != nil {
return ""
}
return string(content)
}
func getHostFromXFH(s string) (string, error) {
if strings.Contains(s, ":") {
realHost, _, err := net.SplitHostPort(s)

23
x-ui.sh Normal file → Executable file
View file

@ -18,9 +18,6 @@ function LOGI() {
echo -e "${green}[INF] $* ${plain}"
}
# check root
[[ $EUID -ne 0 ]] && LOGE "ERROR: You must be root to run this script! \n" && exit 1
# Check OS and set release variable
if [[ -f /etc/os-release ]]; then
source /etc/os-release
@ -28,6 +25,8 @@ if [[ -f /etc/os-release ]]; then
elif [[ -f /usr/lib/os-release ]]; then
source /usr/lib/os-release
release=$ID
elif command -v sw_vers &> /dev/null; then
release="macos"
else
echo "Failed to check the system OS, please contact the author!" >&2
exit 1
@ -36,7 +35,11 @@ fi
echo "The OS release is: $release"
os_version=""
os_version=$(grep "^VERSION_ID" /etc/os-release | cut -d '=' -f2 | tr -d '"' | tr -d '.')
if [[ "${release}" != "macos" ]]; then
os_version=$(grep "^VERSION_ID" /etc/os-release | cut -d '=' -f2 | tr -d '"' | tr -d '.')
# check root
[[ $EUID -ne 0 ]] && LOGE "ERROR: You must be root to run this script! \n" && exit 1
fi
if [[ "${release}" == "arch" ]]; then
echo "Your OS is Arch Linux"
@ -86,6 +89,8 @@ elif [[ "${release}" == "ol" ]]; then
if [[ ${os_version} -lt 8 ]]; then
echo -e "${red} Please use Oracle Linux 8 or higher ${plain}\n" && exit 1
fi
elif [[ "${release}" == "macos" ]]; then
echo "Your OS is MacOS"
else
echo -e "${red}Your operating system is not supported by this script.${plain}\n"
echo "Please ensure you are using one of the following supported operating systems:"
@ -103,6 +108,7 @@ else
echo "- Oracle Linux 8+"
echo "- OpenSUSE Tumbleweed"
echo "- Amazon Linux 2023"
echo "- MacOS (build only)"
exit 1
fi
@ -1277,6 +1283,11 @@ run_speedtest() {
speedtest
}
build_image_tar() {
docker compose version;
docker compose --progress plain build --no-cache && docker save -o 3x-ui.tar 3x-ui:latest && echo "Image saved: 3x-ui.tar";
}
create_iplimit_jails() {
# Use default bantime if not passed => 15 minutes
local bantime="${1:-15}"
@ -1684,6 +1695,7 @@ show_menu() {
${green}23.${plain} Enable BBR
${green}24.${plain} Update Geo Files
${green}25.${plain} Speedtest by Ookla
${green}99.${plain} Build Docker Image (tar archive)
"
show_status
echo && read -p "Please enter your selection [0-25]: " num
@ -1767,6 +1779,9 @@ show_menu() {
25)
run_speedtest
;;
99)
build_image_tar
;;
*)
LOGE "Please enter the correct number [0-25]"
;;