首次提交
Some checks failed
Build and Release / build-and-test (arm64, alpine) (push) Successful in 8s
Build and Release / build-and-test (amd64, alpine) (push) Successful in 14s
Build and Release / build-and-test (arm64, ubuntu) (push) Successful in 14s
Build and Release / build-and-test (amd64, ubuntu) (push) Successful in 23s
Build and Release / release (push) Failing after 26s

This commit is contained in:
Wang Defa
2025-12-03 13:58:47 +08:00
commit 8d3b14d3df
10 changed files with 588 additions and 0 deletions

85
debian/build-deb.sh vendored Executable file
View File

@@ -0,0 +1,85 @@
#!/bin/bash
set -e
# 参数检查
if [ $# -ne 3 ]; then
echo "Usage: $0 <ARCH> <VERSION> <TARGZ_FILE>"
echo "Example: $0 amd64 3.4.6-xg1 xxxigcc-proxy-amd64-ubuntu-3.4.6-xg1.tar.gz"
exit 1
fi
ARCH=$1
VERSION=$2
TARGZ_FILE=$3
PKG_NAME="xxxigcc-proxy"
DEB_FILE="${PKG_NAME}_${VERSION}_${ARCH}.deb"
# 转换架构名称Docker 使用的架构名到 Debian 架构名)
case "$ARCH" in
amd64)
DEB_ARCH="amd64"
;;
arm64)
DEB_ARCH="arm64"
;;
*)
echo "Unsupported architecture: $ARCH"
exit 1
;;
esac
echo "📦 Building Debian package: ${DEB_FILE}"
echo " Architecture: ${DEB_ARCH}"
echo " Version: ${VERSION}"
echo " Source: ${TARGZ_FILE}"
# 创建临时目录
BUILD_DIR=$(mktemp -d)
trap "rm -rf $BUILD_DIR" EXIT
# 创建包目录结构
PKG_DIR="${BUILD_DIR}/${PKG_NAME}_${VERSION}_${DEB_ARCH}"
mkdir -p "${PKG_DIR}/DEBIAN"
mkdir -p "${PKG_DIR}/opt/xxxigcc-proxy"
mkdir -p "${PKG_DIR}/lib/systemd/system"
# 解压二进制文件
echo "📂 Extracting binary..."
tar -xzf "${TARGZ_FILE}" -C "${PKG_DIR}/opt/xxxigcc-proxy"
# 生成 control 文件
echo "📝 Generating control file..."
sed -e "s/{{VERSION}}/${VERSION}/" \
-e "s/{{ARCH}}/${DEB_ARCH}/" \
debian/control.template > "${PKG_DIR}/DEBIAN/control"
# 复制维护脚本
echo "📋 Copying maintainer scripts..."
cp debian/postinst "${PKG_DIR}/DEBIAN/postinst"
cp debian/prerm "${PKG_DIR}/DEBIAN/prerm"
cp debian/postrm "${PKG_DIR}/DEBIAN/postrm"
chmod 755 "${PKG_DIR}/DEBIAN/postinst"
chmod 755 "${PKG_DIR}/DEBIAN/prerm"
chmod 755 "${PKG_DIR}/DEBIAN/postrm"
# 复制 systemd service 文件
echo "🔧 Installing systemd service..."
cp debian/xxxigcc-proxy.service "${PKG_DIR}/lib/systemd/system/"
# 设置权限
chmod 755 "${PKG_DIR}/opt/xxxigcc-proxy/xxxigcc-proxy"
chmod 644 "${PKG_DIR}/opt/xxxigcc-proxy/config.json"
chmod 644 "${PKG_DIR}/lib/systemd/system/xxxigcc-proxy.service"
# 构建 deb 包
echo "🔨 Building package..."
dpkg-deb --build --root-owner-group "${PKG_DIR}" "${DEB_FILE}"
# 检查包
echo "✅ Package built successfully!"
echo "📦 Package: $(pwd)/${DEB_FILE}"
echo "📊 Package info:"
dpkg-deb --info "${DEB_FILE}"
echo ""
echo "🎉 Done!"

16
debian/control.template vendored Normal file
View File

@@ -0,0 +1,16 @@
Package: xxxigcc-proxy
Version: {{VERSION}}
Section: net
Priority: optional
Architecture: {{ARCH}}
Depends: libc6, libuv1, libssl3 | libssl1.1, libhwloc15 | libhwloc5
Maintainer: XXXigCC Team <noreply@example.com>
Homepage: https://github.com/Bendr0id/xmrigcc-proxy
Description: Cryptocurrency mining proxy
XXXigCC Proxy is a customized build of xmrigcc-proxy,
a cryptocurrency mining proxy server.
.
This package includes:
- The xxxigcc-proxy binary
- Systemd service configuration
- Default configuration file

50
debian/postinst vendored Normal file
View File

@@ -0,0 +1,50 @@
#!/bin/sh
set -e
# Create user and group if they don't exist
if ! getent group xxxigcc-proxy >/dev/null; then
addgroup --system xxxigcc-proxy
fi
if ! getent passwd xxxigcc-proxy >/dev/null; then
adduser --system --ingroup xxxigcc-proxy --no-create-home \
--home /opt/xxxigcc-proxy --shell /usr/sbin/nologin \
--gecos "XXXigCC Proxy Service" xxxigcc-proxy
fi
# Create log directory
mkdir -p /var/log/xxxigcc-proxy
chown xxxigcc-proxy:xxxigcc-proxy /var/log/xxxigcc-proxy
chmod 750 /var/log/xxxigcc-proxy
# Create config directory
mkdir -p /etc/xxxigcc-proxy
# Copy default config if it doesn't exist
if [ ! -f /etc/xxxigcc-proxy/config.json ]; then
cp /opt/xxxigcc-proxy/config.json /etc/xxxigcc-proxy/config.json
chown xxxigcc-proxy:xxxigcc-proxy /etc/xxxigcc-proxy/config.json
chmod 640 /etc/xxxigcc-proxy/config.json
fi
# Set permissions
chown -R xxxigcc-proxy:xxxigcc-proxy /opt/xxxigcc-proxy
chmod 755 /opt/xxxigcc-proxy
chmod 755 /opt/xxxigcc-proxy/xxxigcc-proxy
# Reload systemd
if [ -d /run/systemd/system ]; then
systemctl daemon-reload
# Enable and start service
if ! systemctl is-enabled xxxigcc-proxy.service >/dev/null 2>&1; then
systemctl enable xxxigcc-proxy.service
fi
# Start service if not running
if ! systemctl is-active xxxigcc-proxy.service >/dev/null 2>&1; then
systemctl start xxxigcc-proxy.service
fi
fi
exit 0

30
debian/postrm vendored Normal file
View File

@@ -0,0 +1,30 @@
#!/bin/sh
set -e
case "$1" in
purge)
# Remove log directory
rm -rf /var/log/xxxigcc-proxy
# Remove config directory
rm -rf /etc/xxxigcc-proxy
# Remove user and group
if getent passwd xxxigcc-proxy >/dev/null; then
deluser --system xxxigcc-proxy 2>/dev/null || true
fi
if getent group xxxigcc-proxy >/dev/null; then
delgroup --system xxxigcc-proxy 2>/dev/null || true
fi
;;
remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear)
# Reload systemd
if [ -d /run/systemd/system ]; then
systemctl daemon-reload
fi
;;
esac
exit 0

15
debian/prerm vendored Normal file
View File

@@ -0,0 +1,15 @@
#!/bin/sh
set -e
# Stop service before removal
if [ -d /run/systemd/system ]; then
if systemctl is-active xxxigcc-proxy.service >/dev/null 2>&1; then
systemctl stop xxxigcc-proxy.service
fi
if systemctl is-enabled xxxigcc-proxy.service >/dev/null 2>&1; then
systemctl disable xxxigcc-proxy.service
fi
fi
exit 0

39
debian/xxxigcc-proxy.service vendored Normal file
View File

@@ -0,0 +1,39 @@
[Unit]
Description=XXXigCC Proxy Service
After=network.target
[Service]
Type=simple
# 工作目录
WorkingDirectory=/opt/xxxigcc-proxy
# 执行命令
ExecStart=/opt/xxxigcc-proxy/xxxigcc-proxy --config=/etc/xxxigcc-proxy/config.json --log-file=/var/log/xxxigcc-proxy/proxy.log --access-log-file=/var/log/xxxigcc-proxy/access.log
# 重启策略
Restart=always
RestartSec=10
# 用户和组
User=xxxigcc-proxy
Group=xxxigcc-proxy
# 安全设置
NoNewPrivileges=true
PrivateTmp=true
ProtectSystem=strict
ProtectHome=true
ReadWritePaths=/var/log/xxxigcc-proxy
# 日志设置
StandardOutput=journal
StandardError=journal
SyslogIdentifier=xxxigcc-proxy
# 资源限制
LimitNOFILE=65535
LimitNPROC=4096
[Install]
WantedBy=multi-user.target