mirror of
https://github.com/rustfs/rustfs.git
synced 2026-01-17 01:30:33 +00:00
wip
This commit is contained in:
517
.github/workflows/release.yml
vendored
517
.github/workflows/release.yml
vendored
@@ -1,517 +0,0 @@
|
||||
# Copyright 2024 RustFS Team
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
# ⚠️ DEPRECATED: This workflow has been deprecated
|
||||
# Release logic has been merged into build.yml to avoid cross-workflow artifact access issues.
|
||||
# This file is kept for reference but is no longer active.
|
||||
|
||||
name: Release (Deprecated)
|
||||
|
||||
on:
|
||||
# Disabled - release logic is now in build.yml
|
||||
# workflow_run:
|
||||
# workflows: ["Build and Release"]
|
||||
# types: [completed]
|
||||
# branches: [main]
|
||||
# Manual trigger for standalone release creation (disabled)
|
||||
# workflow_dispatch:
|
||||
# inputs:
|
||||
# tag:
|
||||
# description: "Tag to create release for"
|
||||
# required: true
|
||||
# type: string
|
||||
|
||||
# This workflow is disabled - only manual trigger with specific confirmation
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
confirm_deprecated:
|
||||
description: "This workflow is deprecated. Type 'CONFIRM' to run anyway."
|
||||
required: true
|
||||
type: string
|
||||
|
||||
env:
|
||||
CARGO_TERM_COLOR: always
|
||||
|
||||
jobs:
|
||||
# Warning job to inform users this workflow is deprecated
|
||||
deprecated-warning:
|
||||
name: ⚠️ Deprecated Workflow Warning
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Display deprecation warning
|
||||
run: |
|
||||
echo "🚨 WARNING: This workflow has been DEPRECATED 🚨"
|
||||
echo ""
|
||||
echo "Release functionality has been moved to the build.yml workflow"
|
||||
echo "to resolve cross-workflow artifact access issues."
|
||||
echo ""
|
||||
echo "Please use tag pushes to trigger releases automatically via build.yml"
|
||||
echo ""
|
||||
if [[ "${{ github.event.inputs.confirm_deprecated }}" != "CONFIRM" ]]; then
|
||||
echo "❌ To run this deprecated workflow anyway, you must type 'CONFIRM' in the input field."
|
||||
echo "⚠️ However, this workflow may not work correctly due to artifact access limitations."
|
||||
exit 1
|
||||
fi
|
||||
echo "⚠️ Proceeding with deprecated workflow as requested..."
|
||||
|
||||
# Determine release type and check if we should proceed
|
||||
release-check:
|
||||
name: Release Type Check
|
||||
needs: deprecated-warning
|
||||
if: github.event.inputs.confirm_deprecated == 'CONFIRM'
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
tag: ${{ steps.check.outputs.tag }}
|
||||
version: ${{ steps.check.outputs.version }}
|
||||
is_prerelease: ${{ steps.check.outputs.is_prerelease }}
|
||||
release_type: ${{ steps.check.outputs.release_type }}
|
||||
should_release: ${{ steps.check.outputs.should_release }}
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- name: Determine release type
|
||||
id: check
|
||||
run: |
|
||||
should_release=false
|
||||
tag=""
|
||||
version=""
|
||||
is_prerelease=false
|
||||
release_type="release"
|
||||
|
||||
if [[ "${{ github.event_name }}" == "workflow_run" ]]; then
|
||||
# Triggered by build workflow completion
|
||||
echo "🔗 Triggered by build workflow completion"
|
||||
|
||||
# Only proceed if the build workflow was successful
|
||||
if [[ "${{ github.event.workflow_run.conclusion }}" != "success" ]]; then
|
||||
echo "❌ Build workflow failed (conclusion: ${{ github.event.workflow_run.conclusion }}), skipping release"
|
||||
should_release=false
|
||||
else
|
||||
echo "✅ Build workflow succeeded, checking if this is a tag push"
|
||||
|
||||
# Check if this was triggered by a tag push
|
||||
if [[ "${{ github.event.workflow_run.event }}" == "push" ]]; then
|
||||
# Extract tag from head_branch for tag pushes
|
||||
head_branch="${{ github.event.workflow_run.head_branch }}"
|
||||
if [[ "$head_branch" =~ ^refs/tags/ ]]; then
|
||||
tag="${head_branch#refs/tags/}"
|
||||
should_release=true
|
||||
echo "🏷️ Tag push detected: $tag"
|
||||
else
|
||||
echo "⏭️ Not a tag push, skipping release (branch: $head_branch)"
|
||||
should_release=false
|
||||
fi
|
||||
else
|
||||
echo "⏭️ Not a push event, skipping release (event: ${{ github.event.workflow_run.event }})"
|
||||
should_release=false
|
||||
fi
|
||||
fi
|
||||
|
||||
echo "🔄 Release triggered by workflow_run:"
|
||||
echo " 📋 Conclusion: ${{ github.event.workflow_run.conclusion }}"
|
||||
echo " 🌿 Branch: ${{ github.event.workflow_run.head_branch }}"
|
||||
echo " 📎 SHA: ${{ github.event.workflow_run.head_sha }}"
|
||||
echo " 🎯 Event: ${{ github.event.workflow_run.event }}"
|
||||
|
||||
elif [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
|
||||
# Manual trigger
|
||||
tag="${{ github.event.inputs.tag }}"
|
||||
should_release=true
|
||||
echo "🎯 Manual release triggered for tag: $tag"
|
||||
fi
|
||||
|
||||
# Process tag if we should proceed
|
||||
if [[ "$should_release" == "true" && -n "$tag" ]]; then
|
||||
version="$tag"
|
||||
|
||||
# Check if this is a prerelease
|
||||
if [[ "$tag" == *"alpha"* ]] || [[ "$tag" == *"beta"* ]] || [[ "$tag" == *"rc"* ]]; then
|
||||
is_prerelease=true
|
||||
if [[ "$tag" == *"alpha"* ]]; then
|
||||
release_type="alpha"
|
||||
elif [[ "$tag" == *"beta"* ]]; then
|
||||
release_type="beta"
|
||||
elif [[ "$tag" == *"rc"* ]]; then
|
||||
release_type="rc"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
echo "should_release=$should_release" >> $GITHUB_OUTPUT
|
||||
echo "tag=$tag" >> $GITHUB_OUTPUT
|
||||
echo "version=$version" >> $GITHUB_OUTPUT
|
||||
echo "is_prerelease=$is_prerelease" >> $GITHUB_OUTPUT
|
||||
echo "release_type=$release_type" >> $GITHUB_OUTPUT
|
||||
|
||||
echo "📊 Release Summary:"
|
||||
echo " - Should release: $should_release"
|
||||
echo " - Tag: $tag"
|
||||
echo " - Version: $version"
|
||||
echo " - Is prerelease: $is_prerelease"
|
||||
echo " - Release type: $release_type"
|
||||
|
||||
# Create GitHub Release
|
||||
create-release:
|
||||
name: Create GitHub Release
|
||||
needs: release-check
|
||||
if: needs.release-check.outputs.should_release == 'true' && github.event.inputs.confirm_deprecated == 'CONFIRM'
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: write
|
||||
outputs:
|
||||
release_id: ${{ steps.create.outputs.release_id }}
|
||||
release_url: ${{ steps.create.outputs.release_url }}
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- name: Create GitHub Release
|
||||
id: create
|
||||
env:
|
||||
GH_TOKEN: ${{ github.token }}
|
||||
run: |
|
||||
TAG="${{ needs.release-check.outputs.tag }}"
|
||||
VERSION="${{ needs.release-check.outputs.version }}"
|
||||
IS_PRERELEASE="${{ needs.release-check.outputs.is_prerelease }}"
|
||||
RELEASE_TYPE="${{ needs.release-check.outputs.release_type }}"
|
||||
|
||||
# Check if release already exists
|
||||
if gh release view "$TAG" >/dev/null 2>&1; then
|
||||
echo "Release $TAG already exists"
|
||||
RELEASE_ID=$(gh release view "$TAG" --json databaseId --jq '.databaseId')
|
||||
RELEASE_URL=$(gh release view "$TAG" --json url --jq '.url')
|
||||
else
|
||||
# Get release notes from tag message
|
||||
RELEASE_NOTES=$(git tag -l --format='%(contents)' "${TAG}")
|
||||
if [[ -z "$RELEASE_NOTES" || "$RELEASE_NOTES" =~ ^[[:space:]]*$ ]]; then
|
||||
if [[ "$IS_PRERELEASE" == "true" ]]; then
|
||||
RELEASE_NOTES="Pre-release ${VERSION} (${RELEASE_TYPE})"
|
||||
else
|
||||
RELEASE_NOTES="Release ${VERSION}"
|
||||
fi
|
||||
fi
|
||||
|
||||
# Create release title
|
||||
if [[ "$IS_PRERELEASE" == "true" ]]; then
|
||||
TITLE="RustFS $VERSION (${RELEASE_TYPE})"
|
||||
else
|
||||
TITLE="RustFS $VERSION"
|
||||
fi
|
||||
|
||||
# Create the release
|
||||
PRERELEASE_FLAG=""
|
||||
if [[ "$IS_PRERELEASE" == "true" ]]; then
|
||||
PRERELEASE_FLAG="--prerelease"
|
||||
fi
|
||||
|
||||
gh release create "$TAG" \
|
||||
--title "$TITLE" \
|
||||
--notes "$RELEASE_NOTES" \
|
||||
$PRERELEASE_FLAG \
|
||||
--draft
|
||||
|
||||
RELEASE_ID=$(gh release view "$TAG" --json databaseId --jq '.databaseId')
|
||||
RELEASE_URL=$(gh release view "$TAG" --json url --jq '.url')
|
||||
fi
|
||||
|
||||
echo "release_id=$RELEASE_ID" >> $GITHUB_OUTPUT
|
||||
echo "release_url=$RELEASE_URL" >> $GITHUB_OUTPUT
|
||||
echo "Created release: $RELEASE_URL"
|
||||
|
||||
# Download and prepare release assets
|
||||
prepare-assets:
|
||||
name: Prepare Release Assets
|
||||
needs: [release-check, create-release]
|
||||
if: github.event.inputs.confirm_deprecated == 'CONFIRM'
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
actions: read
|
||||
outputs:
|
||||
assets_prepared: ${{ steps.prepare.outputs.assets_prepared }}
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Download artifacts from build workflow
|
||||
env:
|
||||
GH_TOKEN: ${{ github.token }}
|
||||
run: |
|
||||
if [[ "${{ github.event_name }}" == "workflow_run" ]]; then
|
||||
# Get the workflow run ID that triggered this workflow
|
||||
WORKFLOW_RUN_ID="${{ github.event.workflow_run.id }}"
|
||||
|
||||
echo "📥 Downloading artifacts from workflow run: $WORKFLOW_RUN_ID"
|
||||
|
||||
# Create artifacts directory
|
||||
mkdir -p ./artifacts
|
||||
|
||||
# List all artifacts from the triggering workflow run
|
||||
echo "📋 Listing artifacts..."
|
||||
gh api repos/${{ github.repository }}/actions/runs/$WORKFLOW_RUN_ID/artifacts \
|
||||
--jq '.artifacts[] | select(.name | startswith("rustfs-")) | {name: .name, download_url: .archive_download_url}' \
|
||||
> artifacts_list.json
|
||||
|
||||
# Download each artifact
|
||||
while IFS= read -r artifact_info; do
|
||||
if [[ -n "$artifact_info" ]]; then
|
||||
name=$(echo "$artifact_info" | jq -r '.name')
|
||||
download_url=$(echo "$artifact_info" | jq -r '.download_url')
|
||||
|
||||
echo "📦 Downloading artifact: $name"
|
||||
|
||||
# Download the artifact zip
|
||||
gh api "$download_url" > "${name}.zip"
|
||||
|
||||
# Extract the artifact (GitHub API returns artifacts as zip files)
|
||||
unzip -q "${name}.zip" -d "./artifacts/"
|
||||
rm "${name}.zip"
|
||||
|
||||
echo "✅ Downloaded and extracted: $name"
|
||||
fi
|
||||
done < <(cat artifacts_list.json | jq -c '.')
|
||||
|
||||
# List what we downloaded
|
||||
echo "📂 Downloaded artifacts:"
|
||||
ls -la ./artifacts/
|
||||
|
||||
elif [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
|
||||
# Manual trigger - need to find the most recent successful build workflow for the tag
|
||||
TAG="${{ needs.release-check.outputs.tag }}"
|
||||
|
||||
echo "🔍 Manual trigger detected, searching for build artifacts for tag: $TAG"
|
||||
|
||||
# Find the most recent successful "Build and Release" workflow run for this tag
|
||||
echo "📋 Searching for workflow runs..."
|
||||
WORKFLOW_RUN_ID=$(gh api repos/${{ github.repository }}/actions/workflows/build.yml/runs \
|
||||
--jq ".workflow_runs[] | select(.head_branch == \"refs/tags/$TAG\" and .conclusion == \"success\") | .id" \
|
||||
| head -n 1)
|
||||
|
||||
if [[ -z "$WORKFLOW_RUN_ID" ]]; then
|
||||
echo "❌ No successful build workflow found for tag $TAG"
|
||||
echo "💡 Please ensure the build workflow has completed successfully for this tag"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "📥 Found build workflow run: $WORKFLOW_RUN_ID"
|
||||
|
||||
# Create artifacts directory
|
||||
mkdir -p ./artifacts
|
||||
|
||||
# List all artifacts from the build workflow run
|
||||
echo "📋 Listing artifacts..."
|
||||
gh api repos/${{ github.repository }}/actions/runs/$WORKFLOW_RUN_ID/artifacts \
|
||||
--jq '.artifacts[] | select(.name | startswith("rustfs-")) | {name: .name, download_url: .archive_download_url}' \
|
||||
> artifacts_list.json
|
||||
|
||||
# Download each artifact
|
||||
while IFS= read -r artifact_info; do
|
||||
if [[ -n "$artifact_info" ]]; then
|
||||
name=$(echo "$artifact_info" | jq -r '.name')
|
||||
download_url=$(echo "$artifact_info" | jq -r '.download_url')
|
||||
|
||||
echo "📦 Downloading artifact: $name"
|
||||
|
||||
# Download the artifact zip
|
||||
gh api "$download_url" > "${name}.zip"
|
||||
|
||||
# Extract the artifact (GitHub API returns artifacts as zip files)
|
||||
unzip -q "${name}.zip" -d "./artifacts/"
|
||||
rm "${name}.zip"
|
||||
|
||||
echo "✅ Downloaded and extracted: $name"
|
||||
fi
|
||||
done < <(cat artifacts_list.json | jq -c '.')
|
||||
|
||||
# List what we downloaded
|
||||
echo "📂 Downloaded artifacts:"
|
||||
ls -la ./artifacts/
|
||||
|
||||
else
|
||||
echo "❌ Unsupported event type: ${{ github.event_name }}"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
- name: Prepare release assets
|
||||
id: prepare
|
||||
run: |
|
||||
VERSION="${{ needs.release-check.outputs.version }}"
|
||||
TAG="${{ needs.release-check.outputs.tag }}"
|
||||
|
||||
mkdir -p ./release-assets
|
||||
|
||||
# Copy and verify artifacts
|
||||
ASSETS_COUNT=0
|
||||
for file in ./artifacts/rustfs-*.zip; do
|
||||
if [[ -f "$file" ]]; then
|
||||
cp "$file" ./release-assets/
|
||||
ASSETS_COUNT=$((ASSETS_COUNT + 1))
|
||||
fi
|
||||
done
|
||||
|
||||
if [[ $ASSETS_COUNT -eq 0 ]]; then
|
||||
echo "❌ No artifacts found!"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
cd ./release-assets
|
||||
|
||||
# Generate checksums
|
||||
if ls *.zip >/dev/null 2>&1; then
|
||||
sha256sum *.zip > SHA256SUMS
|
||||
sha512sum *.zip > SHA512SUMS
|
||||
fi
|
||||
|
||||
# TODO: Add GPG signing for signatures
|
||||
# For now, create placeholder signature files
|
||||
for file in *.zip; do
|
||||
echo "# Signature for $file" > "${file}.asc"
|
||||
echo "# GPG signature will be added in future versions" >> "${file}.asc"
|
||||
done
|
||||
|
||||
echo "assets_prepared=true" >> $GITHUB_OUTPUT
|
||||
|
||||
echo "📦 Prepared assets:"
|
||||
ls -la
|
||||
|
||||
echo "🔢 Asset count: $ASSETS_COUNT"
|
||||
|
||||
- name: Upload prepared assets
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: release-assets-${{ needs.release-check.outputs.tag }}
|
||||
path: ./release-assets/
|
||||
retention-days: 30
|
||||
|
||||
# Upload assets to GitHub Release
|
||||
upload-assets:
|
||||
name: Upload Release Assets
|
||||
needs: [release-check, create-release, prepare-assets]
|
||||
if: github.event.inputs.confirm_deprecated == 'CONFIRM'
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: write
|
||||
steps:
|
||||
- name: Download prepared assets
|
||||
uses: actions/download-artifact@v4
|
||||
with:
|
||||
name: release-assets-${{ needs.release-check.outputs.tag }}
|
||||
path: ./release-assets
|
||||
|
||||
- name: Upload to GitHub Release
|
||||
env:
|
||||
GH_TOKEN: ${{ github.token }}
|
||||
run: |
|
||||
TAG="${{ needs.release-check.outputs.tag }}"
|
||||
|
||||
cd ./release-assets
|
||||
|
||||
# Upload all files
|
||||
for file in *; do
|
||||
if [[ -f "$file" ]]; then
|
||||
echo "📤 Uploading $file..."
|
||||
gh release upload "$TAG" "$file" --clobber
|
||||
fi
|
||||
done
|
||||
|
||||
echo "✅ All assets uploaded successfully"
|
||||
|
||||
# Update latest.json for stable releases only
|
||||
update-latest:
|
||||
name: Update Latest Version
|
||||
needs: [release-check, upload-assets]
|
||||
if: needs.release-check.outputs.is_prerelease == 'false' && github.event.inputs.confirm_deprecated == 'CONFIRM'
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Update latest.json
|
||||
env:
|
||||
OSS_ACCESS_KEY_ID: ${{ secrets.ALICLOUDOSS_KEY_ID }}
|
||||
OSS_ACCESS_KEY_SECRET: ${{ secrets.ALICLOUDOSS_KEY_SECRET }}
|
||||
run: |
|
||||
if [[ -z "$OSS_ACCESS_KEY_ID" ]]; then
|
||||
echo "⚠️ OSS credentials not available, skipping latest.json update"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
VERSION="${{ needs.release-check.outputs.version }}"
|
||||
TAG="${{ needs.release-check.outputs.tag }}"
|
||||
|
||||
# Install ossutil
|
||||
OSSUTIL_VERSION="2.1.1"
|
||||
OSSUTIL_ZIP="ossutil-${OSSUTIL_VERSION}-linux-amd64.zip"
|
||||
OSSUTIL_DIR="ossutil-${OSSUTIL_VERSION}-linux-amd64"
|
||||
|
||||
curl -o "$OSSUTIL_ZIP" "https://gosspublic.alicdn.com/ossutil/v2/${OSSUTIL_VERSION}/${OSSUTIL_ZIP}"
|
||||
unzip "$OSSUTIL_ZIP"
|
||||
chmod +x "${OSSUTIL_DIR}/ossutil"
|
||||
|
||||
# Create latest.json
|
||||
cat > latest.json << EOF
|
||||
{
|
||||
"version": "${VERSION}",
|
||||
"tag": "${TAG}",
|
||||
"release_date": "$(date -u +%Y-%m-%dT%H:%M:%SZ)",
|
||||
"release_type": "stable",
|
||||
"download_url": "https://github.com/${{ github.repository }}/releases/tag/${TAG}"
|
||||
}
|
||||
EOF
|
||||
|
||||
# Upload to OSS
|
||||
./${OSSUTIL_DIR}/ossutil cp latest.json oss://rustfs-version/latest.json --force
|
||||
|
||||
echo "✅ Updated latest.json for stable release $VERSION"
|
||||
|
||||
# Publish release (remove draft status)
|
||||
publish-release:
|
||||
name: Publish Release
|
||||
needs: [release-check, create-release, upload-assets]
|
||||
if: github.event.inputs.confirm_deprecated == 'CONFIRM'
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: write
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Update release notes and publish
|
||||
env:
|
||||
GH_TOKEN: ${{ github.token }}
|
||||
run: |
|
||||
TAG="${{ needs.release-check.outputs.tag }}"
|
||||
VERSION="${{ needs.release-check.outputs.version }}"
|
||||
IS_PRERELEASE="${{ needs.release-check.outputs.is_prerelease }}"
|
||||
RELEASE_TYPE="${{ needs.release-check.outputs.release_type }}"
|
||||
|
||||
# Get original release notes from tag
|
||||
ORIGINAL_NOTES=$(git tag -l --format='%(contents)' "${TAG}")
|
||||
if [[ -z "$ORIGINAL_NOTES" || "$ORIGINAL_NOTES" =~ ^[[:space:]]*$ ]]; then
|
||||
if [[ "$IS_PRERELEASE" == "true" ]]; then
|
||||
ORIGINAL_NOTES="Pre-release ${VERSION} (${RELEASE_TYPE})"
|
||||
else
|
||||
ORIGINAL_NOTES="Release ${VERSION}"
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
|
||||
# Publish the release (remove draft status)
|
||||
gh release edit "$TAG" --draft=false
|
||||
|
||||
echo "🎉 Released $TAG successfully!"
|
||||
echo "📄 Release URL: ${{ needs.create-release.outputs.release_url }}"
|
||||
Reference in New Issue
Block a user