mirror of
https://github.com/shadow1ng/fscan.git
synced 2025-09-14 14:06:44 +08:00

- 修复发布工作流安全问题,仅标签触发发布 - 优化权限配置,最小化权限分配 - 固定Action版本号,确保构建一致性 - 添加路径过滤,避免文档变更触发构建 - 增强缓存策略,加速构建过程 - 调整超时时间,提高构建效率
313 lines
15 KiB
YAML
313 lines
15 KiB
YAML
name: 发布构建
|
||
|
||
on:
|
||
push:
|
||
tags:
|
||
- 'v*'
|
||
workflow_dispatch:
|
||
inputs:
|
||
tag:
|
||
description: '发布标签'
|
||
required: false
|
||
default: ''
|
||
draft:
|
||
description: '创建草稿发布'
|
||
type: boolean
|
||
default: false
|
||
prerelease:
|
||
description: '标记为预发布'
|
||
type: boolean
|
||
default: false
|
||
|
||
permissions:
|
||
contents: write # 需要写权限用于创建release
|
||
|
||
jobs:
|
||
goreleaser:
|
||
name: 构建和发布
|
||
runs-on: ubuntu-latest
|
||
timeout-minutes: 45
|
||
|
||
# 设置作业级别的环境变量
|
||
env:
|
||
GITHUB_OWNER: ${{ github.repository_owner }}
|
||
GITHUB_REPO: ${{ github.event.repository.name }}
|
||
PROJECT_NAME: ${{ github.event.repository.name }}
|
||
|
||
steps:
|
||
- name: 📥 检出代码
|
||
uses: actions/checkout@v4.1.1
|
||
with:
|
||
fetch-depth: 0
|
||
token: ${{ secrets.GITHUB_TOKEN }}
|
||
|
||
- name: 🔍 获取项目信息
|
||
id: project
|
||
run: |
|
||
echo "owner=${GITHUB_REPOSITORY_OWNER}" >> $GITHUB_OUTPUT
|
||
echo "repo=${GITHUB_REPOSITORY#*/}" >> $GITHUB_OUTPUT
|
||
|
||
# 获取标签版本
|
||
echo "version=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT
|
||
echo "is_tag=true" >> $GITHUB_OUTPUT
|
||
echo "branch_or_tag=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT
|
||
|
||
echo "full_sha=${GITHUB_SHA}" >> $GITHUB_OUTPUT
|
||
echo "short_sha=${GITHUB_SHA:0:7}" >> $GITHUB_OUTPUT
|
||
echo "build_date=$(date -u +"%Y-%m-%d %H:%M:%S UTC")" >> $GITHUB_OUTPUT
|
||
echo "build_timestamp=$(date +%s)" >> $GITHUB_OUTPUT
|
||
|
||
- name: 🐹 设置 Go 环境
|
||
uses: actions/setup-go@v5.0.0
|
||
with:
|
||
go-version: '1.20'
|
||
cache: true
|
||
|
||
- name: 💾 缓存Go模块
|
||
uses: actions/cache@v4.0.0
|
||
with:
|
||
path: |
|
||
~/.cache/go-build
|
||
~/go/pkg/mod
|
||
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
|
||
restore-keys: |
|
||
${{ runner.os }}-go-
|
||
|
||
- name: 📦 下载依赖
|
||
run: |
|
||
go mod download
|
||
go mod verify
|
||
|
||
- name: 🗜️ 安装 UPX 压缩工具
|
||
uses: crazy-max/ghaction-upx@v3.0.0
|
||
with:
|
||
install-only: true
|
||
|
||
- name: ℹ️ 显示构建环境信息
|
||
run: |
|
||
echo "Go 版本: $(go version)"
|
||
echo "UPX 版本: $(upx --version)"
|
||
echo "发布标签: ${{ steps.project.outputs.branch_or_tag }}"
|
||
echo "构建模式: 发布模式"
|
||
echo "提交: ${{ steps.project.outputs.short_sha }}"
|
||
echo "仓库: ${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}"
|
||
echo "构建时间: ${{ steps.project.outputs.build_date }}"
|
||
echo "环境变量:"
|
||
echo "- GITHUB_OWNER: $GITHUB_OWNER"
|
||
echo "- GITHUB_REPO: $GITHUB_REPO"
|
||
echo "- PROJECT_NAME: $PROJECT_NAME"
|
||
|
||
- name: 📊 记录构建开始时间
|
||
id: build_start
|
||
run: |
|
||
echo "start_time=$(date +%s)" >> $GITHUB_OUTPUT
|
||
echo "start_readable=$(date -u +"%Y-%m-%d %H:%M:%S UTC")" >> $GITHUB_OUTPUT
|
||
|
||
- name: 🚀 构建和发布
|
||
id: build_step
|
||
uses: goreleaser/goreleaser-action@v5.0.0
|
||
with:
|
||
distribution: goreleaser
|
||
version: latest
|
||
args: release --clean -f .github/conf/.goreleaser.yml ${{ inputs.draft && '--draft' || '' }} ${{ inputs.prerelease && '--prerelease' || '' }}
|
||
workdir: .
|
||
env:
|
||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||
GITHUB_REPO: ${{ github.event.repository.name }}
|
||
GITHUB_OWNER: ${{ github.repository_owner }}
|
||
PROJECT_NAME: ${{ github.event.repository.name }}
|
||
continue-on-error: true
|
||
|
||
- name: 📊 记录构建结束时间
|
||
id: build_end
|
||
run: |
|
||
echo "end_time=$(date +%s)" >> $GITHUB_OUTPUT
|
||
echo "end_readable=$(date -u +"%Y-%m-%d %H:%M:%S UTC")" >> $GITHUB_OUTPUT
|
||
start_time=${{ steps.build_start.outputs.start_time }}
|
||
end_time=$(date +%s)
|
||
duration=$((end_time - start_time))
|
||
echo "duration=${duration}" >> $GITHUB_OUTPUT
|
||
echo "duration_readable=$(printf '%02d:%02d:%02d' $((duration/3600)) $((duration%3600/60)) $((duration%60)))" >> $GITHUB_OUTPUT
|
||
|
||
- name: 📋 上传构建产物
|
||
uses: actions/upload-artifact@v4.3.1
|
||
if: always()
|
||
with:
|
||
name: 发布产物-${{ steps.project.outputs.version }}
|
||
path: |
|
||
dist/
|
||
retention-days: 90
|
||
continue-on-error: true
|
||
|
||
- name: 📊 统计构建产物
|
||
id: build_stats
|
||
run: |
|
||
if [ -d "dist" ]; then
|
||
total_files=$(find dist/ -type f | wc -l)
|
||
executable_files=$(find dist/ -type f -executable | wc -l)
|
||
config_files=$(find dist/ -name "*.json" -o -name "*.yaml" -o -name "*.yml" -o -name "*.txt" | wc -l)
|
||
|
||
# 平台统计
|
||
linux_count=$(find dist/ -name "*linux*" -type f | wc -l)
|
||
darwin_count=$(find dist/ -name "*darwin*" -type f | wc -l)
|
||
windows_count=$(find dist/ -name "*windows*" -type f | wc -l)
|
||
|
||
echo "total_files=$total_files" >> $GITHUB_OUTPUT
|
||
echo "executable_files=$executable_files" >> $GITHUB_OUTPUT
|
||
echo "config_files=$config_files" >> $GITHUB_OUTPUT
|
||
echo "linux_count=$linux_count" >> $GITHUB_OUTPUT
|
||
echo "darwin_count=$darwin_count" >> $GITHUB_OUTPUT
|
||
echo "windows_count=$windows_count" >> $GITHUB_OUTPUT
|
||
else
|
||
echo "total_files=0" >> $GITHUB_OUTPUT
|
||
echo "executable_files=0" >> $GITHUB_OUTPUT
|
||
echo "config_files=0" >> $GITHUB_OUTPUT
|
||
echo "linux_count=0" >> $GITHUB_OUTPUT
|
||
echo "darwin_count=0" >> $GITHUB_OUTPUT
|
||
echo "windows_count=0" >> $GITHUB_OUTPUT
|
||
fi
|
||
|
||
- name: 📊 生成发布报告
|
||
if: always()
|
||
run: |
|
||
# 构建状态判断
|
||
if [[ "${{ steps.build_step.outcome }}" == "success" ]]; then
|
||
build_status=""
|
||
release_status=""
|
||
else
|
||
build_status=""
|
||
release_status=""
|
||
fi
|
||
|
||
echo "# 🎉 发布构建报告" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "$build_status $release_status" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 基本信息
|
||
echo "## 📋 发布基本信息" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 项目 | 值 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "|------|-----|" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🏷️ **项目名称** | ${{ steps.project.outputs.repo }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 👤 **拥有者** | ${{ steps.project.outputs.owner }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🏷️ **版本** | \`${{ steps.project.outputs.version }}\` |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 📝 **提交SHA** | \`${{ steps.project.outputs.short_sha }}\` |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 📅 **构建时间** | ${{ steps.project.outputs.build_date }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| ⏱️ **构建耗时** | ${{ steps.build_end.outputs.duration_readable }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🚀 **触发方式** | ${{ github.event_name }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🔧 **Go版本** | $(go version | cut -d' ' -f3) |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🗜️ **UPX版本** | $(upx --version | head -1 | cut -d' ' -f2) |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🔧 **构建模式** | 发布模式 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 📦 **发布类型** | $(if [[ "${{ inputs.draft }}" == "true" ]]; then echo "草稿"; elif [[ "${{ inputs.prerelease }}" == "true" ]]; then echo "预发布"; else echo "正式发布"; fi) |" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 构建环境信息
|
||
echo "## 🖥️ 构建环境" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 环境变量 | 值 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "|----------|-----|" >> $GITHUB_STEP_SUMMARY
|
||
echo "| **GITHUB_OWNER** | $GITHUB_OWNER |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| **GITHUB_REPO** | $GITHUB_REPO |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| **PROJECT_NAME** | $PROJECT_NAME |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| **RUNNER_OS** | $RUNNER_OS |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| **RUNNER_ARCH** | $RUNNER_ARCH |" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 构建时间统计
|
||
echo "## ⏰ 构建时间统计" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 阶段 | 时间 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "|------|------|" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🚀 **开始时间** | ${{ steps.build_start.outputs.start_readable }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🏁 **结束时间** | ${{ steps.build_end.outputs.end_readable }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| ⏱️ **总耗时** | ${{ steps.build_end.outputs.duration_readable }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 构建结果
|
||
echo "## 🚀 构建结果" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 构建阶段 | 状态 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "|----------|------|" >> $GITHUB_STEP_SUMMARY
|
||
|
||
if [[ "${{ steps.build_step.outcome }}" == "success" ]]; then
|
||
echo "| 🏗️ **构建发布** | ✅ 成功 |" >> $GITHUB_STEP_SUMMARY
|
||
else
|
||
echo "| 🏗️ **构建发布** | ❌ 失败 |" >> $GITHUB_STEP_SUMMARY
|
||
fi
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 发布产物统计
|
||
if [ -d "dist" ]; then
|
||
echo "## 📦 发布产物统计" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 文件类型统计
|
||
echo "### 📊 文件类型统计" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 文件类型 | 数量 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "|----------|------|" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 📁 **总文件数** | ${{ steps.build_stats.outputs.total_files }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🔧 **可执行文件** | ${{ steps.build_stats.outputs.executable_files }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 📄 **配置文件** | ${{ steps.build_stats.outputs.config_files }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 平台分布统计
|
||
echo "### 🌍 平台分布统计" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 平台 | 数量 |" >> $GITHUB_STEP_SUMMARY
|
||
echo "|------|------|" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🐧 **Linux** | ${{ steps.build_stats.outputs.linux_count }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🍎 **macOS** | ${{ steps.build_stats.outputs.darwin_count }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "| 🪟 **Windows** | ${{ steps.build_stats.outputs.windows_count }} |" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 总产物大小
|
||
echo "### 📦 产物大小" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
total_size=$(du -sh dist/ 2>/dev/null | cut -f1 || echo "未知")
|
||
echo "**总产物大小**: $total_size" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
fi
|
||
|
||
# 发布总结
|
||
echo "## 📈 发布总结" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
if [[ "${{ steps.build_step.outcome }}" == "success" ]]; then
|
||
echo "🎉 **构建状态**: ✅ 成功" >> $GITHUB_STEP_SUMMARY
|
||
echo "🎉 **发布状态**: ✅ 成功" >> $GITHUB_STEP_SUMMARY
|
||
echo "🔗 **发布链接**: https://github.com/${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}/releases/tag/${{ steps.project.outputs.version }}" >> $GITHUB_STEP_SUMMARY
|
||
else
|
||
echo "🎉 **构建状态**: ❌ 失败" >> $GITHUB_STEP_SUMMARY
|
||
echo "🎉 **发布状态**: ❌ 失败" >> $GITHUB_STEP_SUMMARY
|
||
fi
|
||
|
||
echo "📊 **可执行文件**: ${{ steps.build_stats.outputs.executable_files }} 个" >> $GITHUB_STEP_SUMMARY
|
||
echo "⏱️ **构建耗时**: ${{ steps.build_end.outputs.duration_readable }}" >> $GITHUB_STEP_SUMMARY
|
||
echo "📦 **产物大小**: $(du -sh dist/ 2>/dev/null | cut -f1 || echo "未知")" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
# 快速链接
|
||
echo "## 🔗 快速链接" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
echo "- 🎯 [查看发布页面](https://github.com/${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}/releases/tag/${{ steps.project.outputs.version }})" >> $GITHUB_STEP_SUMMARY
|
||
echo "- 📋 [查看产物列表](https://github.com/${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}/actions/runs/${{ github.run_id }})" >> $GITHUB_STEP_SUMMARY
|
||
echo "- 📥 [下载产物](https://github.com/${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}/actions/runs/${{ github.run_id }})" >> $GITHUB_STEP_SUMMARY
|
||
echo "- 🔍 [查看提交](https://github.com/${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}/commit/${{ steps.project.outputs.full_sha }})" >> $GITHUB_STEP_SUMMARY
|
||
echo "- 🌿 [查看分支](https://github.com/${{ steps.project.outputs.owner }}/${{ steps.project.outputs.repo }}/tree/${{ steps.project.outputs.branch_or_tag }})" >> $GITHUB_STEP_SUMMARY
|
||
echo "" >> $GITHUB_STEP_SUMMARY
|
||
|
||
echo "---" >> $GITHUB_STEP_SUMMARY
|
||
echo "*报告生成时间: $(date -u +"%Y-%m-%d %H:%M:%S UTC")*" >> $GITHUB_STEP_SUMMARY
|
||
|
||
- name: 📬 发送通知
|
||
if: always()
|
||
run: |
|
||
if [[ "${{ steps.build_step.outcome }}" == "success" ]]; then
|
||
echo "✅ 发布成功!版本 ${{ steps.project.outputs.version }} 已发布"
|
||
# 这里可以添加发送成功通知的逻辑(如 Slack、邮件等)
|
||
else
|
||
echo "❌ 发布失败!请检查构建日志"
|
||
# 这里可以添加发送失败通知的逻辑
|
||
fi |