Skip to content

Generate Release Version #31

Generate Release Version

Generate Release Version #31

Workflow file for this run

name: Generate Release Version
on:
workflow_dispatch:
jobs:
build:
name: Build Release APK
runs-on: macos-14
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup JDK
uses: actions/setup-java@v4
with:
distribution: "temurin"
java-version: "17"
cache: "gradle"
- name: Setup Android SDK
uses: android-actions/setup-android@v3
- name: Install Latest Build Tools
run: |
build_tools_list=$(sdkmanager --list | sed -n 's/.*\(build-tools;[0-9.][0-9.a-zA-Z-]*\).*/\1/p')
stable_build_tools_list=$(echo "$build_tools_list" | grep -v "\-rc")
latest_stable_version=$(echo "$stable_build_tools_list" | sort -V | tail -n 1)
latest_version_number=$(echo $latest_stable_version | sed 's/.*;//')
sdkmanager "$latest_stable_version"
echo "$ANDROID_SDK_ROOT/build-tools/$latest_version_number" >> $GITHUB_PATH
- name: Build Unsigned Release APK
run: ./gradlew assembleRelease
- name: Build Unsigned Release App Bundle
run: ./gradlew bundleRelease
- name: Generate Signing Key
env:
KEYSTORE_B64: ${{ secrets.APP_KEYSTORE }}
run: |
echo $KEYSTORE_B64 | base64 -d > keystore.jks
cp keystore.jks ${{ github.workspace }}/app/build/outputs/bundle/release/keystore.jks
working-directory: ${{ github.workspace }}/app/build/outputs/apk/release
- name: Sign Release APK
env:
SIGNING_PASSWORD: ${{ secrets.KEY_PASSWORD }}
run: |
apksigner sign --ks keystore.jks --alignment-preserved true --ks-pass env:SIGNING_PASSWORD --out app-release.apk app-release-unsigned.apk
working-directory: ${{ github.workspace }}/app/build/outputs/apk/release
- name: Sign Release App Bundle
env:
SIGNING_KEY_ALIAS: ${{ secrets.KEY_ALIAS }}
SIGNING_PASSWORD: ${{ secrets.KEY_PASSWORD }}
run: |
jarsigner -verbose -sigalg SHA256withRSA -digestalg SHA-256 -keystore keystore.jks -keypass $SIGNING_PASSWORD -storepass $SIGNING_PASSWORD app-release.aab $SIGNING_KEY_ALIAS
working-directory: ${{ github.workspace }}/app/build/outputs/bundle/release
- name: Create Job Summary
run: |
unsigned_hash=$(md5 -q ./apk/release/app-release-unsigned.apk)
signed_hash=$(md5 -q ./apk/release/app-release.apk)
signed_aab_hash=$(md5 -q ./bundle/release/app-release.aab)
certificate_hash=$(apksigner verify --print-certs ./apk/release/app-release.apk | grep "SHA-256" | awk -F': ' '{print $2}')
echo "### Release Build Results" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
echo "**Unsigned APK md5**: \`$unsigned_hash\`" >> $GITHUB_STEP_SUMMARY
echo "**Signed APK md5**: \`$signed_hash\`" >> $GITHUB_STEP_SUMMARY
echo "**Signed AAB md5**: \`$signed_aab_hash\`" >> $GITHUB_STEP_SUMMARY
echo "**Certificate SHA-256**: \`$certificate_hash\`" >> $GITHUB_STEP_SUMMARY
working-directory: ${{ github.workspace }}/app/build/outputs
- name: Upload Signed APK
uses: actions/upload-artifact@v4
id: artifact-upload-step
with:
name: release-${{ github.sha }}
path: |
${{ github.workspace }}/app/build/outputs/apk/release/app-release.apk
${{ github.workspace }}/app/build/outputs/bundle/release/app-release.aab