Skip to content

fix: Fix fdroid reproducible builds #40

fix: Fix fdroid reproducible builds

fix: Fix fdroid reproducible builds #40

Workflow file for this run

name: Release Build
on:
push:
tags:
- 'v*'
pull_request:
branches: [ "main" ]
jobs:
Build:
name: Build/Sign APK
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set GOOGLE_API_KEY in local properties
run: echo 'GOOGLE_API_KEY="${{ secrets.GOOGLE_API_KEY }}"' >> ./local.properties
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'temurin'
cache: gradle
- name: Set ANDROID_HOME
run: echo "ANDROID_HOME=$ANDROID_SDK_ROOT" >> $GITHUB_ENV
- name: Get Tag
id: var
run: echo "tag=${GITHUB_REF#refs/*/}" >> $GITHUB_OUTPUT
- name: Build APK
id: build
run: bash ./gradlew assembleRelease
- name: Sign APK
id: sign_apk
shell: bash
run: |
# Get the tag version
TAG_VERSION=$(echo ${{ github.ref }} | sed 's/refs\/tags\/v//')
# Set the APK file path
APK_FILE="app/build/outputs/apk/release/Myne-v${TAG_VERSION}.apk"
# Check if file exists
if [ ! -f "$APK_FILE" ]; then
echo "APK file not found: $APK_FILE"
echo "Contents of app/build/outputs/apk/release:"
ls -l app/build/outputs/apk/release/
exit 1
fi
echo "Found APK file: $APK_FILE"
SIGNED_APK_FILE=app/build/outputs/apk/release/app-release-signed.apk
echo "${{ secrets.BASE64KEY }}" | base64 --decode > /tmp/signingkey.jks
apksigner=${ANDROID_HOME}/build-tools/$(ls ${ANDROID_HOME}/build-tools/ | tail -1)/apksigner
echo "APK Signer Path: $apksigner"
$apksigner sign \
--ks /tmp/signingkey.jks \
--ks-key-alias ${{ secrets.ALIAS }} \
--ks-pass pass:${{ secrets.KEY_STORE_PASSWORD }} \
--key-pass pass:${{ secrets.KEY_PASSWORD }} \
--out $SIGNED_APK_FILE \
--alignment-preserved true \
$APK_FILE
env:
ANDROID_HOME: ${{ env.ANDROID_HOME }}
- name: Make artifact
uses: actions/upload-artifact@v2
with:
name: Signed APP APK
path: app/build/outputs/apk/release/app-release-signed.apk
- name: Build AAB
run: bash ./gradlew bundleRelease
- name: Sign AAB
id: sign_aab
shell: bash
run: |
AAB_FILE=app/build/outputs/bundle/release/app-release.aab
SIGNED_AAB_FILE=app/build/outputs/bundle/release/app-release-signed.aab
echo "${{ secrets.BASE64KEY }}" | base64 --decode > /tmp/signingkey.jks
apksigner=${ANDROID_HOME}/build-tools/$(ls ${ANDROID_HOME}/build-tools/ | tail -1)/apksigner
$apksigner sign \
--ks /tmp/signingkey.jks \
--ks-key-alias ${{ secrets.ALIAS }} \
--ks-pass pass:${{ secrets.KEY_STORE_PASSWORD }} \
--key-pass pass:${{ secrets.KEY_PASSWORD }} \
--out $SIGNED_AAB_FILE \
--alignment-preserved true $AAB_FILE
env:
ANDROID_HOME: ${{ env.ANDROID_HOME }}
- name: Make artifact
uses: actions/upload-artifact@v2
with:
name: Signed APP Bundle
path: app/build/outputs/bundle/release/app-release-signed.aab
- name: Build Changelog
id: changelog
uses: ardalanamini/auto-changelog@v3
with:
mention-authors: false
mention-new-contributors: true
include-compare: true
semver: false
- name: Create Release
id: create_release
uses: actions/create-release@v1
with:
tag_name: ${{ github.ref }}
release_name: Myne ${{ github.ref }}
draft: true
body: ${{ steps.changelog.outputs.changelog }}  
env:
GITHUB_TOKEN: ${{ github.token }}
- name: Upload APK
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ github.token }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: app/build/outputs/apk/release/app-release-signed.apk
asset_name: Myne-${{ steps.var.outputs.tag }}.apk
asset_content_type: application/zip
- name: Upload AAB
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ github.token }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: app/build/outputs/bundle/release/app-release-signed.aab
asset_name: Myne-${{ steps.var.outputs.tag }}.aab
asset_content_type: application/zip