Skip to content

Commit

Permalink
Merge branch 'openMF:dev' into dev
Browse files Browse the repository at this point in the history
  • Loading branch information
niyajali authored Nov 19, 2024
2 parents 5a5966b + 6980ca7 commit 7e60a03
Show file tree
Hide file tree
Showing 41 changed files with 1,957 additions and 1,375 deletions.
6 changes: 3 additions & 3 deletions .github/actions/create-release-notes/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,16 +41,16 @@ runs:
id: version-generator
shell: bash
run: |
mkdir -p ./app/build/outputs/
mkdir -p ./mifospay-android/build/outputs/
echo "Previous Release Tag:"
echo "${{ steps.latest-release-tag.outputs.result }}"
echo "Full Changelog:"
CHANGELOG="${{ steps.generate-notes.outputs.result }}"
echo -e "$CHANGELOG"
printf "$CHANGELOG" > ./mifospay/build/outputs/changelogGithub
printf "$CHANGELOG" > ./mifospay-android/build/outputs/changelogGithub
echo "Beta Changelog:"
git log --format="* %s" HEAD^..HEAD
git log --format="* %s" HEAD^..HEAD > ./mifospay/build/outputs/changelogBeta
git log --format="* %s" HEAD^..HEAD > ./mifospay-android/build/outputs/changelogBeta
9 changes: 4 additions & 5 deletions .github/actions/inflate-secrets/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,26 +16,25 @@ runs:
- name: Mock debug google-services.json
shell: bash
run: |
cp .github/mock-google-services.json mifospay/src/demo/google-services.json
cp .github/mock-google-services.json mifospay/src/prod/google-services.json
cp .github/mock-google-services.json mifospay-android/google-services.json
- name: Inflate release_keystore.keystore
shell: bash
env:
KEYSTORE: ${{ inputs.keystore }}
run: |
echo $KEYSTORE | base64 --decode > mifospay/release_keystore.keystore
echo $KEYSTORE | base64 --decode > mifospay-android/release_keystore.keystore
- name: Inflate google-services.json
shell: bash
env:
GOOGLE_SERVICES: ${{ inputs.google-services }}
run: |
echo $GOOGLE_SERVICES > mifospay/google-services.json
echo $GOOGLE_SERVICES > mifospay-android/google-services.json
- name: Inflate playStorePublishServiceCredentialsFile.json
shell: bash
env:
CREDS: ${{ inputs.playstore-creds }}
run: |
echo $CREDS > mifospay/playStorePublishServiceCredentialsFile.json
echo $CREDS > mifospay-android/playStorePublishServiceCredentialsFile.json
Original file line number Diff line number Diff line change
@@ -1,22 +1,49 @@
name: On Push
name: Internal Or Beta Release

on:
workflow_dispatch:
inputs:
beta:
description: 'true if this is a beta release'
release_type:
required: false
default: 'false'
push:
branches:
- master
default: 'internal'
description: Please select the release type
type: choice
options:
- internal
- beta

env:
SUPPLY_UPLOAD_MAX_RETRIES: 5

jobs:
build_desktop_app:
strategy:
matrix:
os:
- macos-latest
- ubuntu-latest
- windows-latest

runs-on: ${{ matrix.os }}
permissions:
contents: write
steps:
- uses: actions/checkout@v4
- uses: actions/setup-java@v4
with:
distribution: 'zulu'
java-version: 17

- name: Build Desktop App
env:
NOTARIZATION_APPLE_ID: ${{ secrets.NOTARIZATION_APPLE_ID }}
NOTARIZATION_PASSWORD: ${{ secrets.NOTARIZATION_PASSWORD }}
NOTARIZATION_TEAM_ID: ${{ secrets.NOTARIZATION_TEAM_ID }}
run: ./gradlew packageReleaseDistributionForCurrentOS

app_build:
name: Github, Firebase, and Sentry Release
needs: [ build_desktop_app ]
runs-on: ubuntu-latest
permissions:
contents: write
Expand Down Expand Up @@ -63,33 +90,37 @@ jobs:
KEYSTORE_ALIAS_PASSWORD: ${{ secrets.ORIGINAL_KEYSTORE_ALIAS_PASSWORD }}
VERSION_CODE: ${{ steps.rel_number.outputs.version-code }}
run: |
./gradlew :mifospay:assembleRelease
./gradlew :mifospay-android:assembleRelease
- name: Archive Build
uses: actions/upload-artifact@v4
with:
path: ./**/*.apk

- name: Create Version File
if: github.event.inputs.beta == 'true'
if: github.event.inputs.release_type == 'beta'
shell: bash
env:
VERSION_CODE: ${{ steps.rel_number.outputs.version-code }}
run: |
echo $VERSION_CODE > ./app/build/outputs/version_code.txt
echo $VERSION_CODE > ./mifospay-android/build/outputs/version_code.txt
- name: Create Github Pre-Release
if: github.event.inputs.beta == 'true'
if: github.event.inputs.release_type == 'beta'
uses: softprops/[email protected]
with:
tag_name: ${{ steps.rel_number.outputs.version }}
body_path: ./app/build/outputs/changelogGithub
body_path: ./mifospay-android/build/outputs/changelogGithub
draft: false
prerelease: true
files: |
./mifospay/build/outputs/apk/demo/release/mifospay-demo-release.apk
./mifospay/build/outputs/apk/prod/release/mifospay-prod-release.apk
./mifospay/build/outputs/version_code.txt
./mifospay-android/build/outputs/apk/demo/release/mifospay-android-demo-release.apk
./mifospay-android/build/outputs/apk/prod/release/mifospay-android-prod-release.apk
./mifospay-android/build/outputs/version_code.txt
./mifospay-desktop/build/compose/binaries/main-release/exe/*.exe
./mifospay-desktop/build/compose/binaries/main-release/msi/*.msi
./mifospay-desktop/build/compose/binaries/main-release/deb/*.deb
./mifospay-desktop/build/compose/binaries/main-release/dmg/*.dmg
- name: Print `git status`
run: git status
Expand Down Expand Up @@ -144,11 +175,11 @@ jobs:
KEYSTORE_ALIAS_PASSWORD: ${{ secrets.UPLOAD_KEYSTORE_ALIAS_PASSWORD }}
VERSION_CODE: ${{ steps.rel_number.outputs.version-code }}
run: |
./gradlew :mifospay:bundleRelease
./gradlew :mifospay-android:bundleRelease
- name: Deploy to Playstore Internal
run: bundle exec fastlane deploy_internal

- name: Promote Internal to Beta
if: github.event.inputs.beta == 'true'
if: github.event.inputs.release_type == 'beta'
run: bundle exec fastlane promote_to_beta
49 changes: 49 additions & 0 deletions .github/workflows/make_site.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
name: Publish Web App

on:
# Runs on pushes targeting the default branch
push:
branches: ["dev"]

# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:

# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write

# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: "pages"
cancel-in-progress: false

jobs:
build_web_app:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-java@v4
with:
distribution: 'zulu'
java-version: 17

- name: Build Web(JS) App
run: ./gradlew jsBrowserDistribution

- name: Setup Pages
uses: actions/configure-pages@v5

- name: Upload static files as artifact
uses: actions/upload-pages-artifact@v3
with:
path: './mifospay-web/build/dist/js/productionExecutable/'

- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4
50 changes: 49 additions & 1 deletion .github/workflows/master_dev_ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ name: Mobile-Wallet CI[Master/Dev]

on:
push:
branches: [ dev, master, payment_hub ]
branches: [ dev ]
pull_request:

concurrency:
Expand Down Expand Up @@ -62,6 +62,8 @@ jobs:
**/build/reports/detekt/detekt.md
dependency_guard:
needs: setup
runs-on: ubuntu-latest
Expand Down Expand Up @@ -120,6 +122,8 @@ jobs:
**/build/reports/lint-results-*.html
**/build/test-results/test*UnitTest/**.xml
build:
needs: [ checks, dependency_guard, tests_and_lint ]
runs-on: ubuntu-latest
Expand All @@ -144,3 +148,47 @@ jobs:
name: APKs
path: '**/build/outputs/apk/**/*.apk'

build_desktop_app:
needs: [ checks, dependency_guard, tests_and_lint ]
strategy:
matrix:
os:
- windows-latest
- ubuntu-latest
- macos-latest

runs-on: ${{ matrix.os }}
permissions:
contents: write
steps:
- uses: actions/checkout@v4
- uses: actions/setup-java@v4
with:
distribution: 'zulu'
java-version: 17

- name: Build Desktop App
run: ./gradlew packageDistributionForCurrentOS

- name: Upload Windows Apps
if: matrix.os == 'windows-latest'
uses: actions/upload-artifact@v4
with:
name: Windows-App
path: |
./mifospay-desktop/build/compose/binaries/main/exe/*.exe
./mifospay-desktop/build/compose/binaries/main/msi/*.msi
- name: Upload Linux App
if: matrix.os == 'ubuntu-latest'
uses: actions/upload-artifact@v4
with:
name: Windows-App
path: './mifospay-desktop/build/compose/binaries/main/deb/*.deb'

- name: Upload MacOS App
if: matrix.os == 'macos-latest'
uses: actions/upload-artifact@v4
with:
name: Windows-App
path: './mifospay-desktop/build/compose/binaries/main/dmg/*.dmg'
6 changes: 2 additions & 4 deletions .github/workflows/monthly.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,8 @@ name: Bump our Calendar Version

on:
workflow_dispatch:
# This is a monthly cron job that runs on the first of the month at 3:30 AM UTC
# Turning off for now
# schedule:
# - cron: '30 3 1 * *'
schedule:
- cron: '30 3 1 * *'
jobs:
tag:
name: Tag Monthly Release
Expand Down
12 changes: 5 additions & 7 deletions .github/workflows/weekly.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,8 @@ name: Tag Weekly Release

on:
workflow_dispatch:
# This is a weekly cron job that runs every Sunday at 4:00 AM UTC
# Turning off for now
# schedule:
# - cron: '0 4 * * 0'
schedule:
- cron: '0 4 */2 * 0'
jobs:
tag:
name: Tag Weekly Release
Expand Down Expand Up @@ -33,9 +31,9 @@ jobs:
github.rest.actions.createWorkflowDispatch({
owner: context.repo.owner,
repo: context.repo.repo,
workflow_id: 'onPush.yml',
ref: 'master',
workflow_id: 'internal_or_beta_release.yml',
ref: 'dev',
inputs: {
"beta": "true",
"release_type": "beta",
},
})
3 changes: 3 additions & 0 deletions Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -209,7 +209,10 @@ GEM
xcpretty (~> 0.2, >= 0.0.7)

PLATFORMS
arm64-darwin-22
x64-mingw-ucrt
x86_64-linux


DEPENDENCIES
fastlane
Expand Down
Loading

0 comments on commit 7e60a03

Please sign in to comment.