chore: update release files

This commit is contained in:
cogwheel0
2025-08-29 13:38:55 +05:30
parent 4323965d4f
commit e7494d0408
2 changed files with 112 additions and 9 deletions

View File

@@ -4,6 +4,17 @@ on:
push: push:
tags: tags:
- 'v*' - 'v*'
workflow_dispatch:
inputs:
tag:
description: 'Existing release tag to update (e.g. v1.2.3)'
required: true
type: string
remove_old_assets:
description: 'Remove existing assets before uploading new ones'
required: false
default: true
type: boolean
jobs: jobs:
build-android: build-android:
@@ -35,6 +46,38 @@ jobs:
- name: Generate Freezed Classes - name: Generate Freezed Classes
run: flutter pub run build_runner build --delete-conflicting-outputs run: flutter pub run build_runner build --delete-conflicting-outputs
- name: Determine Release Tag and Version
id: meta
shell: bash
run: |
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
RELEASE_TAG="${{ inputs.tag }}"
else
RELEASE_TAG="${{ github.ref_name }}"
fi
echo "RELEASE_TAG=$RELEASE_TAG" >> $GITHUB_ENV
# Derive VERSION_NAME (strip leading v)
VERSION_NAME="${RELEASE_TAG#v}"
echo "VERSION_NAME=$VERSION_NAME" >> $GITHUB_ENV
# Extract current build number from pubspec.yaml if present, otherwise 1
CURRENT_VERSION_LINE=$(grep "^version:" pubspec.yaml || true)
CURRENT_BUILD=$(echo "$CURRENT_VERSION_LINE" | awk -F'+' '{print $2}')
if [[ -z "$CURRENT_BUILD" ]]; then CURRENT_BUILD=1; fi
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
# Rebuild mode: compute a unique, monotonic build number without committing
# Use CI run number offset to avoid conflicts across multiple rebuilds
BASE_BUILD=$CURRENT_BUILD
RUN_NUM=${GITHUB_RUN_NUMBER:-1}
BUILD_NUMBER=$((BASE_BUILD + RUN_NUM))
else
# Tag build: honor the build number committed in pubspec, default to CURRENT_BUILD
BUILD_NUMBER="$CURRENT_BUILD"
fi
echo "BUILD_NUMBER=$BUILD_NUMBER" >> $GITHUB_ENV
echo "Using tag=$RELEASE_TAG version=$VERSION_NAME build=$BUILD_NUMBER"
#5 Setup Keystore #5 Setup Keystore
- name: Create Keystore - name: Create Keystore
run: | run: |
@@ -46,10 +89,10 @@ jobs:
working-directory: android working-directory: android
- name: Build APK - name: Build APK
run: flutter build apk --release run: flutter build apk --release --build-name "$VERSION_NAME" --build-number "$BUILD_NUMBER"
- name: Build appBundle - name: Build appBundle
run: flutter build appbundle --release run: flutter build appbundle --release --build-name "$VERSION_NAME" --build-number "$BUILD_NUMBER"
- name: Upload Artifacts - name: Upload Artifacts
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
@@ -79,12 +122,27 @@ jobs:
echo "RELEASE_NOTES<<EOF" >> $GITHUB_OUTPUT echo "RELEASE_NOTES<<EOF" >> $GITHUB_OUTPUT
cat release_notes.md >> $GITHUB_OUTPUT cat release_notes.md >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT echo "EOF" >> $GITHUB_OUTPUT
if: github.event_name == 'push'
- name: Create Release - name: Create or Update Release (tag push)
if: github.event_name == 'push'
uses: ncipollo/release-action@v1 uses: ncipollo/release-action@v1
with: with:
artifacts: "build/app/outputs/flutter-apk/app-release.apk,build/app/outputs/bundle/release/app-release.aab" artifacts: "build/app/outputs/flutter-apk/app-release.apk,build/app/outputs/bundle/release/app-release.aab"
tag: ${{ github.ref_name }} tag: ${{ env.RELEASE_TAG }}
token: ${{ secrets.GITHUB_TOKEN }} token: ${{ secrets.GITHUB_TOKEN }}
body: ${{ steps.release_notes.outputs.RELEASE_NOTES }} body: ${{ steps.release_notes.outputs.RELEASE_NOTES }}
generateReleaseNotes: true generateReleaseNotes: true
allowUpdates: true
- name: Update Existing Release (manual rebuild)
if: github.event_name == 'workflow_dispatch'
uses: ncipollo/release-action@v1
with:
artifacts: "build/app/outputs/flutter-apk/app-release.apk,build/app/outputs/bundle/release/app-release.aab"
tag: ${{ env.RELEASE_TAG }}
token: ${{ secrets.GITHUB_TOKEN }}
allowUpdates: true
removeArtifacts: ${{ inputs.remove_old_assets }}
makeLatest: true
omitBodyDuringUpdate: true

View File

@@ -1,7 +1,9 @@
#!/bin/bash #!/bin/bash
# LuCI Mobile Release Script (CI-driven) # Conduit Mobile Release Script (CI-driven)
# Usage: ./scripts/release.sh [major|minor|patch] # Usage:
# ./scripts/release.sh [major|minor|patch]
# ./scripts/release.sh rebuild [vX.Y.Z] # Rebuild existing tag, bump build number only, update same release assets
set -e set -e
@@ -30,6 +32,49 @@ if [ ! -f "pubspec.yaml" ]; then
exit 1 exit 1
fi fi
ACTION=${1:-patch}
if [ "$ACTION" = "rebuild" ]; then
# Rebuild path: Update existing release assets without changing the tag/version name
# Optionally accepts a tag argument; defaults to latest tag.
TAG_ARG=$2
if [ -z "$TAG_ARG" ]; then
TAG_VERSION=$(git describe --tags --abbrev=0)
else
TAG_VERSION=$TAG_ARG
fi
if [ -z "$TAG_VERSION" ]; then
print_error "No tag found. Provide an explicit tag: ./scripts/release.sh rebuild vX.Y.Z"
exit 1
fi
print_status "Rebuilding existing release for tag: $TAG_VERSION"
echo
read -p "Proceed to rebuild $TAG_VERSION and update its assets? (y/N): " -n 1 -r
echo
if [[ ! $REPLY =~ ^[Yy]$ ]]; then
print_warning "Rebuild cancelled"
exit 0
fi
if command -v gh >/dev/null 2>&1; then
print_status "Dispatching GitHub Actions workflow (Release) via gh CLI..."
gh workflow run "Release" \
--ref main \
-f tag="$TAG_VERSION" \
-f remove_old_assets=true
print_status "Workflow dispatched. Track progress in GitHub Actions."
else
print_warning "GitHub CLI (gh) not found. Trigger the workflow manually:"
echo "- Go to: https://github.com/$(git config --get remote.origin.url | sed -E 's#(git@|https://)([^/:]+)[:/]([^/.]+/[^.]+)(\.git)?#\2/\3#')/actions/workflows/release.yml"
echo "- Click 'Run workflow', set tag to $TAG_VERSION, and run."
fi
exit 0
fi
# Standard release path (major/minor/patch)
# Check if git is clean # Check if git is clean
if [ -n "$(git status --porcelain)" ]; then if [ -n "$(git status --porcelain)" ]; then
print_error "Working directory is not clean. Please commit or stash your changes first." print_error "Working directory is not clean. Please commit or stash your changes first."
@@ -47,7 +92,7 @@ MINOR=${VERSION_PARTS[1]}
PATCH=${VERSION_PARTS[2]} PATCH=${VERSION_PARTS[2]}
# Determine release type # Determine release type
RELEASE_TYPE=${1:-patch} RELEASE_TYPE=$ACTION
case $RELEASE_TYPE in case $RELEASE_TYPE in
major) major)
@@ -66,7 +111,7 @@ case $RELEASE_TYPE in
NEW_PATCH=$((PATCH + 1)) NEW_PATCH=$((PATCH + 1))
;; ;;
*) *)
print_error "Invalid release type. Use: major, minor, or patch" print_error "Invalid command. Use: major | minor | patch | rebuild [vX.Y.Z]"
exit 1 exit 1
;; ;;
esac esac