Files
huanld 2fb067ecbf
checklocks / checklocks (push) Has been cancelled
CodeQL / Analyze (go) (push) Has been cancelled
natlab-integrationtest / natlab-integrationtest (push) Has been cancelled
CI / gomod-cache (push) Has been cancelled
CI / race-root-integration (1/4) (push) Has been cancelled
CI / race-root-integration (2/4) (push) Has been cancelled
CI / race-root-integration (3/4) (push) Has been cancelled
CI / race-root-integration (4/4) (push) Has been cancelled
CI / test (-race, amd64, 1/3) (push) Has been cancelled
CI / test (-race, amd64, 2/3) (push) Has been cancelled
CI / test (-race, amd64, 3/3) (push) Has been cancelled
CI / test (386) (push) Has been cancelled
CI / test (amd64) (push) Has been cancelled
CI / Windows (benchmarks) (push) Has been cancelled
CI / Windows (1/2) (push) Has been cancelled
CI / Windows (2/2) (push) Has been cancelled
CI / macos (push) Has been cancelled
CI / privileged (push) Has been cancelled
CI / vm (push) Has been cancelled
CI / cross (386, linux) (push) Has been cancelled
CI / cross (amd64, darwin) (push) Has been cancelled
CI / cross (amd64, freebsd) (push) Has been cancelled
CI / cross (amd64, openbsd) (push) Has been cancelled
CI / cross (amd64, windows) (push) Has been cancelled
CI / cross (arm, 5, linux) (push) Has been cancelled
CI / cross (arm, 7, linux) (push) Has been cancelled
CI / cross (arm64, darwin) (push) Has been cancelled
CI / cross (arm64, linux) (push) Has been cancelled
CI / cross (arm64, windows) (push) Has been cancelled
CI / cross (loong64, linux) (push) Has been cancelled
CI / ios (push) Has been cancelled
CI / crossmin (amd64, illumos) (push) Has been cancelled
CI / crossmin (amd64, plan9) (push) Has been cancelled
CI / crossmin (amd64, solaris) (push) Has been cancelled
CI / crossmin (ppc64, aix) (push) Has been cancelled
CI / android (push) Has been cancelled
CI / wasm (push) Has been cancelled
CI / tailscale_go (push) Has been cancelled
CI / fuzz (push) Has been cancelled
CI / depaware (push) Has been cancelled
CI / go_generate (push) Has been cancelled
CI / make_tidy (push) Has been cancelled
CI / licenses (push) Has been cancelled
CI / staticcheck (macOS) (push) Has been cancelled
CI / staticcheck (Linux) (push) Has been cancelled
CI / staticcheck (Windows) (push) Has been cancelled
CI / staticcheck (Portable (1/4)) (push) Has been cancelled
CI / staticcheck (Portable (2/4)) (push) Has been cancelled
CI / staticcheck (Portable (3/4)) (push) Has been cancelled
CI / staticcheck (Portable (4/4)) (push) Has been cancelled
CI / notify_slack (push) Has been cancelled
CI / merge_blocker (push) Has been cancelled
CI / check_mergeability_strict (push) Has been cancelled
CI / check_mergeability (push) Has been cancelled
Dockerfile build / deploy (push) Has been cancelled
test installer.sh / test (curl, alpine:3.21) (push) Has been cancelled
test installer.sh / test (curl, alpine:edge) (push) Has been cancelled
test installer.sh / test (curl, alpine:latest) (push) Has been cancelled
test installer.sh / test (curl, amazonlinux:latest) (push) Has been cancelled
test installer.sh / test (curl, archlinux:latest) (push) Has been cancelled
test installer.sh / test (curl, debian:oldstable-slim) (push) Has been cancelled
test installer.sh / test (curl, debian:sid-slim) (push) Has been cancelled
test installer.sh / test (curl, debian:stable-slim, 1.80.0) (push) Has been cancelled
test installer.sh / test (curl, debian:testing-slim) (push) Has been cancelled
test installer.sh / test (curl, elementary/docker:stable) (push) Has been cancelled
test installer.sh / test (curl, elementary/docker:unstable) (push) Has been cancelled
test installer.sh / test (curl, fedora:latest, 1.80.0) (push) Has been cancelled
test installer.sh / test (curl, kalilinux/kali-dev) (push) Has been cancelled
test installer.sh / test (curl, kalilinux/kali-rolling) (push) Has been cancelled
test installer.sh / test (curl, opensuse/leap:latest) (push) Has been cancelled
test installer.sh / test (curl, opensuse/tumbleweed:latest) (push) Has been cancelled
test installer.sh / test (curl, oraclelinux:8) (push) Has been cancelled
test installer.sh / test (curl, oraclelinux:9) (push) Has been cancelled
test installer.sh / test (curl, parrotsec/core:latest) (push) Has been cancelled
test installer.sh / test (curl, rockylinux:8.7) (push) Has been cancelled
test installer.sh / test (curl, rockylinux:9) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:20.04) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:22.04) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:24.04, 1.80.0) (push) Has been cancelled
test installer.sh / test (wget, debian:oldstable-slim) (push) Has been cancelled
test installer.sh / test (wget, debian:sid-slim) (push) Has been cancelled
update-flake / update-flake (push) Has been cancelled
tailscale.com/cmd/vet / vet (push) Has been cancelled
test installer.sh / notify-slack (push) Has been cancelled
feat: security hardening, production roadmap, admin panel v1
Client security fixes (cmd/tailscale-tray/main.go):
- SSRF protection in Add Server dialog (validateControlURL): reject
  private/loopback/link-local/cloud-metadata IPs via DNS resolution
- RCE gate on AuthURL/BrowseToURL exec paths (validateAuthURL)
- Sanitized URL logging (sanitizeURLForLog drops query auth tokens)
- Error handling on exec.Command with user-facing showError()

Admin panel security (web-admin):
- Bcrypt password hashing (replaces SHA256)
- Rate limiting: 5 failed logins → 15-min lockout
- Session + login attempt cleanup goroutine (hourly)
- url.QueryEscape / encodeURIComponent for all API params
- Fail-hard startup when no TLS and non-loopback bind
- ADMIN_PASSWORD required (no default), password min 12 chars
- Username regex whitelist

Installer hardening (Setup.wxs):
- util:PermissionEx restricts SCM access: only Administrators +
  SYSTEM can start/stop/reconfigure service. Authenticated Users
  limited to QueryStatus/QueryConfig/Interrogate
- Vital="yes" on ServiceInstall

Docs & roadmap:
- PRODUCTION_ROADMAP.md: 5-milestone plan (security + features +
  distribution + ops) with granular tasks, effort, done-when
- CLIENT_SECURITY_AUDIT.md, SECURITY_FIXES.md, DEPLOYMENT.md
- AI assistant rules (.cursorrules, .antigravityrules, etc.)

Build & distribution:
- build-msi.ps1, deploy-and-sign.ps1, sign-release.ps1
- redeploy.ps1, tray-deploy.ps1, test-msi.ps1
- installer/msi/ alternative WXS setup
- Restored .github/workflows/ removed in mirror cleanup

.gitignore hardened: *.pfx, *.p12, *.key, *.pem, .env*
2026-04-22 15:18:11 +07:00

6.8 KiB

📦 Hướng Dẫn Triển Khai Tailscale Custom Admin Panel

🚀 Triển Khai Nhanh (Quick Start)

1. Tạo File .env

# Production deployment
cat > .env << 'EOF'
HEADSCALE_API_KEY=<generated-api-key-from-headscale>
ADMIN_PASSWORD=<strong-password-min-12-chars>
TLS_CERT_FILE=/certs/cert.pem
TLS_KEY_FILE=/certs/key.pem
TLS_CERT_DIR=./certs
EOF

2. Tạo Certificates (Self-signed)

mkdir -p certs
cd certs

# Self-signed certificate (tự ký)
openssl req -x509 -newkey rsa:4096 \
  -keyout key.pem \
  -out cert.pem \
  -days 365 -nodes \
  -subj "/CN=localhost"

cd ..

3. Khởi Động với Docker Compose

# Load environment variables
export HEADSCALE_API_KEY="your-api-key"
export ADMIN_PASSWORD="YourStrongPassword123!"

# Start services
docker compose up -d

# Kiểm tra logs
docker compose logs -f headscale-admin

4. Truy Cập Admin Panel

https://localhost:9080
Username: admin
Password: YourStrongPassword123!

🔐 Biến Môi Trường (Environment Variables)

Bắt Buộc (Required)

Biến Mô Tả Ví Dụ
ADMIN_PASSWORD Mật khẩu admin (min 12 chars) SecurePass2024!
HEADSCALE_API_KEY API key từ Headscale ts_prd_...

Tùy Chọn (Optional)

Biến Mặc Định Mô Tả
HEADSCALE_URL http://headscale:8080 URL Headscale server
LISTEN_ADDR :9080 Port admin panel
DATA_DIR /data Thư mục lưu users.json
TLS_CERT_FILE (none) Đường dẫn certificate
TLS_KEY_FILE (none) Đường dẫn private key

📋 Danh Sách Kiểm Tra Triển Khai (Pre-Deployment Checklist)

  • HEADSCALE_API_KEY được cấu hình

    # Lấy từ Headscale
    headscale apikey create
    
  • ADMIN_PASSWORD được đặt mạnh (min 12 chars, mixed case, numbers, symbols)

    # Tạo mật khẩu mạnh
    openssl rand -base64 16
    
  • TLS Certificates được tạo

    ls -la certs/cert.pem certs/key.pem
    
  • Docker image được build lại

    docker compose build --no-cache
    
  • Ports khả dụng

    netstat -ln | grep 9080  # Không output = port free
    
  • .env file có permissions chính xác

    chmod 600 .env
    

Kiểm Tra Sau Triển Khai (Post-Deployment Verification)

1. Kiểm Tra Dịch Vụ Hoạt Động

# Kiểm tra containers
docker compose ps
# Nên thấy: headscale ✓, headscale-admin ✓

# Kiểm tra logs
docker compose logs headscale-admin | tail -20
# Nên thấy: "Headscale Web Admin starting on :9080"

2. Kiểm Tra HTTPS

# Test TLS connection
openssl s_client -connect localhost:9080 -showcerts
# Hoặc
curl -v --insecure https://localhost:9080/
# Nên thấy: TLS Handshake success

3. Kiểm Tra Đăng Nhập

# Attempt login
curl -X POST https://localhost:9080/api/auth/login \
  --insecure \
  -H "Content-Type: application/json" \
  -d '{"username":"admin","password":"YOUR_PASSWORD"}'

# Nên nhận về token

4. Kiểm Tra Rate Limiting

#!/bin/bash
# Thử 6 lần đăng nhập sai liên tiếp
for i in {1..6}; do
  echo "Attempt $i:"
  curl -s -X POST https://localhost:9080/api/auth/login \
    --insecure \
    -H "Content-Type: application/json" \
    -d '{"username":"admin","password":"wrongpassword"}' | jq '.error'
done

# Kết quả mong đợi:
# Attempts 1-5: "invalid credentials"
# Attempt 6: "account temporarily locked..."

🔄 Nâng Cấp & Rollback

Cập Nhật Code

# Pull latest changes
git pull origin main

# Rebuild docker image
docker compose down
docker compose build --no-cache

# Start with new code
docker compose up -d

# Verify
docker compose logs headscale-admin

Rollback (Quay Lại Phiên Bản Trước)

# Restore from git
git checkout HEAD~1
docker compose down
docker compose build --no-cache
docker compose up -d

Backup Data

# Backup users.json
docker compose exec headscale-admin \
  cp /data/users.json /data/users.json.backup

# Restore
docker compose exec headscale-admin \
  cp /data/users.json.backup /data/users.json

🛡️ Bảo Mật Tối Ưu (Security Hardening)

Sử Dụng Let's Encrypt Certificates

# Install Certbot
apt-get install certbot python3-certbot-dns-<your-provider>

# Get certificate
certbot certonly --dns-<provider> -d vpn.softs.business

# Update docker-compose.yml
export TLS_CERT_FILE="/etc/letsencrypt/live/vpn.softs.business/fullchain.pem"
export TLS_KEY_FILE="/etc/letsencrypt/live/vpn.softs.business/privkey.pem"

# Restart
docker compose down
docker compose up -d

Firewall Configuration

# UFW (Ubuntu)
ufw allow 9080/tcp
ufw allow 9080/udp

# iptables
iptables -A INPUT -p tcp --dport 9080 -j ACCEPT

Nginx Reverse Proxy

server {
    listen 443 ssl;
    server_name vpn.softs.business;

    ssl_certificate /etc/letsencrypt/live/vpn.softs.business/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/vpn.softs.business/privkey.pem;
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;

    location / {
        proxy_pass https://localhost:9080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

📊 Monitoring

Kiểm Tra CPU/Memory Usage

docker stats headscale-admin

Xem Logs Real-time

docker compose logs -f headscale-admin

Kiểm Tra Disk Space

docker exec headscale-admin du -sh /data

🆘 Khắc Phục Sự Cố (Troubleshooting)

Problem: "ADMIN_PASSWORD is required"

Giải pháp: Đặt biến môi trường

export ADMIN_PASSWORD="YourPassword"
docker compose up -d

Problem: "TLS: certificate required"

Giải pháp: Tạo certificates

./create-certs.sh
docker compose restart headscale-admin

Problem: "Connection refused" (9080)

Giải pháp: Kiểm tra port

netstat -ln | grep 9080
docker compose logs headscale-admin

Problem: "Invalid username/password"

Giải pháp: Reset password

# Xóa users.json để reset admin account
docker exec headscale-admin rm /data/users.json
docker compose restart headscale-admin

📞 Support

Gặp vấn đề? Hãy kiểm tra:

  1. Logs: docker compose logs headscale-admin
  2. Environment variables: docker compose config
  3. Certificates: openssl x509 -in certs/cert.pem -text
  4. Security fixes: Xem SECURITY_FIXES.md

Phiên Bản: 1.0
Cập Nhật Lần Cuối: 2026-04-22
Status: Production Ready