Files
tailscale-custom/deploy-and-sign.ps1
T
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

115 lines
5.4 KiB
PowerShell

# deploy-and-sign.ps1 — ky file, stop service, deploy, start lai
# Chay voi quyen Admin
$ErrorActionPreference = "Stop"
$isAdmin = ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole(
[Security.Principal.WindowsBuiltInRole]::Administrator
)
if (-not $isAdmin) {
Write-Host "Can quyen Admin, dang tu nang quyen..." -ForegroundColor Yellow
$log = "$env:TEMP\deploy-sign-log.txt"
Remove-Item $log -ErrorAction SilentlyContinue
Start-Process powershell -Verb RunAs -Wait `
-ArgumentList "-ExecutionPolicy Bypass -File `"$PSCommandPath`""
Start-Sleep -Milliseconds 800
if (Test-Path $log) { Get-Content $log } else { Write-Warning "Khong co log — UAC bi tu choi?" }
exit
}
Start-Transcript -Path "$env:TEMP\deploy-sign-log.txt" -Force | Out-Null
$distDir = "C:\Users\huanld\tailscale\dist"
$destDir = "C:\Program Files\Tailscale-Custom"
$files = @("tailscaled.exe", "tailscale.exe")
# ────────────────────────────────────────────────
# 1. Lay cert
# ────────────────────────────────────────────────
Write-Host "`n=== KY FILE ===" -ForegroundColor Cyan
$cert = Get-ChildItem Cert:\LocalMachine\My |
Where-Object { $_.Subject -eq "CN=Tailscale-Custom, O=SoftsBusiness, C=VN" -and $_.HasPrivateKey } |
Sort-Object NotAfter -Descending |
Select-Object -First 1
if (-not $cert) {
Write-Error "Khong tim thay code-signing cert trong LocalMachine\My!"
Stop-Transcript | Out-Null
exit 1
}
Write-Host " Dung cert: $($cert.Thumbprint)"
# ────────────────────────────────────────────────
# 2. Ky tung file trong dist\
# ────────────────────────────────────────────────
foreach ($name in $files) {
$path = Join-Path $distDir $name
if (-not (Test-Path $path)) { Write-Warning " Khong tim thay: $path"; continue }
# Thu ky voi timestamp
$r = Set-AuthenticodeSignature -FilePath $path -Certificate $cert `
-TimestampServer "http://timestamp.digicert.com" -HashAlgorithm SHA256 `
-ErrorAction SilentlyContinue
if (-not $r -or $r.Status -notin @("Valid")) {
Write-Warning " Timestamp loi ($($r.StatusMessage)), ky khong timestamp..."
$r = Set-AuthenticodeSignature -FilePath $path -Certificate $cert -HashAlgorithm SHA256
}
if ($r.Status -eq "Valid") {
Write-Host " [OK] $name" -ForegroundColor Green
} else {
Write-Host " [~] $name => $($r.Status)$($r.StatusMessage)" -ForegroundColor Yellow
}
}
# ────────────────────────────────────────────────
# 3. Dung service + process
# ────────────────────────────────────────────────
Write-Host "`n=== DUNG SERVICE ===" -ForegroundColor Cyan
Stop-Service "Tailscale-Custom" -Force -ErrorAction SilentlyContinue
Stop-Process -Name tailscaled -Force -ErrorAction SilentlyContinue
Start-Sleep -Seconds 2
Write-Host " Service da dung"
# ────────────────────────────────────────────────
# 4. Copy vao Program Files
# ────────────────────────────────────────────────
Write-Host "`n=== COPY FILES ===" -ForegroundColor Cyan
foreach ($name in $files) {
$src = Join-Path $distDir $name
$dst = Join-Path $destDir $name
if (-not (Test-Path $src)) { Write-Warning " Khong tim thay: $src"; continue }
Copy-Item $src $dst -Force
$sz = [math]::Round((Get-Item $dst).Length / 1MB, 1)
Write-Host " [OK] $name -> $dst ($sz MB)" -ForegroundColor Green
}
# ────────────────────────────────────────────────
# 5. Start service
# ────────────────────────────────────────────────
Write-Host "`n=== START SERVICE ===" -ForegroundColor Cyan
Start-Service "Tailscale-Custom"
Start-Sleep -Seconds 4
$svc = Get-Service "Tailscale-Custom"
if ($svc.Status -eq "Running") {
Write-Host " [OK] Service dang chay: $($svc.Status)" -ForegroundColor Green
} else {
Write-Host " [!!] Service status: $($svc.Status)" -ForegroundColor Red
}
# ────────────────────────────────────────────────
# 6. Kiem tra chu ky trong Program Files
# ────────────────────────────────────────────────
Write-Host "`n=== XAC NHAN CHU KY ===" -ForegroundColor Cyan
foreach ($name in $files) {
$path = Join-Path $destDir $name
if (-not (Test-Path $path)) { continue }
$sig = Get-AuthenticodeSignature -FilePath $path
Write-Host " $name => $($sig.Status) [$($sig.SignerCertificate.Thumbprint)]"
}
Write-Host "`n=== HOAN THANH ===" -ForegroundColor Green
Stop-Transcript | Out-Null