Skip to content

chore: Bump version to v1.15.3+61 #61

chore: Bump version to v1.15.3+61

chore: Bump version to v1.15.3+61 #61

Workflow file for this run

name: App Release
on:
push:
tags:
- 'v[0-9]+.[0-9]+.[0-9]+\+[0-9]+'
- 'pre-v[0-9]+.[0-9]+.[0-9]+\+[0-9]+'
env:
PROPERTIES_PATH: "./android/key.properties"
jobs:
analyzing:
uses: ./.github/workflows/_analyze.yml
testing:
uses: ./.github/workflows/_test.yml
testing-report:
permissions:
contents: read
actions: read
checks: write
needs:
- testing
uses: ./.github/workflows/_test_report.yml
pre-build:
name: Pre Building
needs:
- analyzing
- testing
- testing-report
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Released - Basic
uses: ncipollo/release-action@v1
with:
draft: true
prerelease: ${{ startsWith(github.ref_name, 'pre-') }}
bodyFile: "docs/release.md"
artifactErrorsFailBuild: true
token: ${{ secrets.APP_RELEASE_TOKEN }}
build-android:
name: Build android APK
needs:
- pre-build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: ./.github/actions/setup_jdk
- uses: ./.github/actions/setup_flutter
- name: Signing APK
run: |
echo keyPassword=\${{ secrets.APP_SIGN_KEY_PASSWORD }} > ${{env.PROPERTIES_PATH}}
echo storePassword=\${{ secrets.APP_SIGN_STORE_PASSWORD }} >> ${{env.PROPERTIES_PATH}}
echo keyAlias=\${{ secrets.APP_SIGN_KEY_ALIAS }} >> ${{env.PROPERTIES_PATH}}
echo storeFile=key.jks >> ${{env.PROPERTIES_PATH}}
echo "${{ secrets.APP_SIGN_KEY_JKS }}" | base64 --decode > android/app/key.jks
- name: Build APPBUNDLE
run: flutter build appbundle --release
- name: Build FAT-APK
run: |
flutter build apk --release
md5sum build/app/outputs/flutter-apk/app-release.apk
- name: Build APK
run: flutter build apk --split-per-abi
- name: Released - Android
uses: ncipollo/release-action@v1
with:
allowUpdates: true
omitBodyDuringUpdate: true
omitDraftDuringUpdate: true
omitPrereleaseDuringUpdate: true
artifacts: >
build/app/outputs/bundle/release/app-release.aab,
build/app/outputs/flutter-apk/app-release.apk,
build/app/outputs/flutter-apk/app-armeabi-v7a-release.apk,
build/app/outputs/flutter-apk/app-arm64-v8a-release.apk,
build/app/outputs/flutter-apk/app-x86_64-release.apk
token: ${{ secrets.APP_RELEASE_TOKEN }}
build-macos-dmg:
name: "Build macos DMG"
needs:
- pre-build
runs-on: macos-latest
steps:
- uses: actions/checkout@v4
- uses: ./.github/actions/setup_flutter
- name: Build APP
run: flutter build macos --release
- uses: actions/setup-node@v4
with:
node-version: 20
token: ${{ secrets.APP_RELEASE_TOKEN }}
- run: npm install -g appdmg
- name: Build DMP
run: appdmg ./installers/dmg_creator/config.json ./build/macos/Build/Products/Release/mhabit.dmg
- name: Released - MacOS
uses: ncipollo/release-action@v1
with:
allowUpdates: true
omitBodyDuringUpdate: true
omitDraftDuringUpdate: true
omitPrereleaseDuringUpdate: true
artifacts: >
build/macos/Build/Products/Release/mhabit.dmg
token: ${{ secrets.APP_RELEASE_TOKEN }}
build-windows-msix:
name: "Build windows MSIX Installer"
needs:
- pre-build
runs-on: windows-latest
steps:
- uses: actions/checkout@v4
- uses: ./.github/actions/setup_flutter
- name: Exposed Certificate
shell: bash
run: echo "${{ secrets.APP_SIGN_KEY_PFX }}" | base64 --decode > windows/certificate/publish.pfx
- name: Build MSIX
run: .flutter\bin\dart run msix:create --architecture x64 --output-name mhabit_x64 --certificate-path windows\certificate\publish.pfx --certificate-password '${{ secrets.APP_SIGN_KEY_PFX_PASSWORD }}' --install-certificate false
- name: Released - Windows
uses: ncipollo/release-action@v1
with:
allowUpdates: true
omitBodyDuringUpdate: true
omitDraftDuringUpdate: true
omitPrereleaseDuringUpdate: true
artifacts: >
build/windows/x64/runner/Release/mhabit_x64.msix
token: ${{ secrets.APP_RELEASE_TOKEN }}