name: Build Authenticator on: push: branches: - main - release/**/* workflow_dispatch: inputs: version-name: description: "Optional. Version string to use, in X.Y.Z format. Overrides default in the project." required: false type: string version-code: description: "Optional. Build number to use. Overrides default of GitHub run number." required: false type: number patch_version: description: "Order 999 - Overrides Patch version" type: boolean distribute-to-firebase: description: "Optional. Distribute artifacts to Firebase." required: false default: true type: boolean publish-to-play-store: description: "Optional. Deploy bundle artifact to Google Play Store" required: false default: true type: boolean env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} DISTRIBUTE_TO_FIREBASE: ${{ inputs.distribute-to-firebase || github.event_name == 'push' }} PUBLISH_TO_PLAY_STORE: ${{ inputs.publish-to-play-store || github.event_name == 'push' }} permissions: contents: read packages: read jobs: version: name: Calculate Version Name and Number uses: bitwarden/android/.github/workflows/_version.yml@main with: app_codename: "bwa" base_version_number: 0 version_name: ${{ inputs.version-name }} version_number: ${{ inputs.version-code }} patch_version: ${{ inputs.patch_version && '999' || '' }} publish_playstore: name: Publish Authenticator Play Store artifacts needs: - version runs-on: ubuntu-24.04 permissions: id-token: write strategy: fail-fast: false matrix: variant: ["aab", "apk"] steps: - name: Check out repo uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 with: persist-credentials: false - name: Log in to Azure uses: bitwarden/gh-actions/azure-login@main with: subscription_id: ${{ secrets.AZURE_SUBSCRIPTION_ID }} tenant_id: ${{ secrets.AZURE_TENANT_ID }} client_id: ${{ secrets.AZURE_CLIENT_ID }} - name: Get Azure Key Vault secrets id: get-kv-secrets uses: bitwarden/gh-actions/get-keyvault-secrets@main with: keyvault: gh-android secrets: "BWA-AAB-KEYSTORE-STORE-PASSWORD,BWA-AAB-KEYSTORE-KEY-PASSWORD,BWA-APK-KEYSTORE-STORE-PASSWORD,BWA-APK-KEYSTORE-KEY-PASSWORD" - name: Retrieve secrets env: ACCOUNT_NAME: bitwardenci CONTAINER_NAME: mobile run: | mkdir -p ${{ github.workspace }}/secrets mkdir -p ${{ github.workspace }}/keystores az storage blob download --account-name "$ACCOUNT_NAME" --container-name "$CONTAINER_NAME" \ --name authenticator_apk-keystore.jks --file ${{ github.workspace }}/keystores/authenticator_apk-keystore.jks --output none az storage blob download --account-name "$ACCOUNT_NAME" --container-name "$CONTAINER_NAME" \ --name authenticator_aab-keystore.jks --file ${{ github.workspace }}/keystores/authenticator_aab-keystore.jks --output none az storage blob download --account-name "$ACCOUNT_NAME" --container-name "$CONTAINER_NAME" \ --name com.bitwarden.authenticator-google-services.json --file ${{ github.workspace }}/authenticator/src/google-services.json --output none az storage blob download --account-name "$ACCOUNT_NAME" --container-name "$CONTAINER_NAME" \ --name com.bitwarden.authenticator.dev-google-services.json --file ${{ github.workspace }}/authenticator/src/debug/google-services.json --output none - name: Download Firebase credentials if: ${{ env.DISTRIBUTE_TO_FIREBASE }} env: ACCOUNT_NAME: bitwardenci CONTAINER_NAME: mobile run: | mkdir -p ${{ github.workspace }}/secrets az storage blob download --account-name "$ACCOUNT_NAME" --container-name "$CONTAINER_NAME" \ --name authenticator_play_firebase-creds.json --file ${{ github.workspace }}/secrets/authenticator_play_firebase-creds.json --output none - name: Download Play Store credentials if: ${{ env.PUBLISH_TO_PLAY_STORE }} env: ACCOUNT_NAME: bitwardenci CONTAINER_NAME: mobile run: | mkdir -p ${{ github.workspace }}/secrets az storage blob download --account-name "$ACCOUNT_NAME" --container-name "$CONTAINER_NAME" \ --name authenticator_play_store-creds.json --file ${{ github.workspace }}/secrets/authenticator_play_store-creds.json --output none - name: AZ Logout uses: bitwarden/gh-actions/azure-logout@main - name: Setup Android Build uses: ./.github/actions/setup-android-build - name: Verify Play Store credentials if: ${{ env.PUBLISH_TO_PLAY_STORE }} run: | bundle exec fastlane run validate_play_store_json_key \ json_key:"${{ github.workspace }}/secrets/authenticator_play_store-creds.json" - name: Update app CI Build info run: | ./scripts/update_app_ci_build_info.sh \ "$GITHUB_REPOSITORY" \ "$GITHUB_REF_NAME" \ "$GITHUB_SHA" \ "$GITHUB_RUN_ID" \ "$GITHUB_RUN_ATTEMPT" - name: Increment version env: VERSION_CODE: ${{ needs.version.outputs.version_number || github.run_number }} VERSION_NAME: ${{ needs.version.outputs.version_name }} run: ./.github/scripts/set-build-version.sh "$VERSION_CODE" "$VERSION_NAME" - name: Generate release Play Store bundle if: ${{ matrix.variant == 'aab' }} env: STORE_PASSWORD: ${{ steps.get-kv-secrets.outputs.BWA-AAB-KEYSTORE-STORE-PASSWORD }} KEY_PASSWORD: ${{ steps.get-kv-secrets.outputs.BWA-AAB-KEYSTORE-KEY-PASSWORD }} run: | bundle exec fastlane bundleAuthenticatorRelease \ storeFile:"${{ github.workspace }}/keystores/authenticator_aab-keystore.jks" \ storePassword:"$STORE_PASSWORD" \ keyAlias:"authenticatorupload" \ keyPassword:"$KEY_PASSWORD" - name: Generate release Play Store APK if: ${{ matrix.variant == 'apk' }} env: STORE_PASSWORD: ${{ steps.get-kv-secrets.outputs.BWA-APK-KEYSTORE-STORE-PASSWORD }} KEY_PASSWORD: ${{ steps.get-kv-secrets.outputs.BWA-APK-KEYSTORE-KEY-PASSWORD }} run: | bundle exec fastlane buildAuthenticatorRelease \ storeFile:"${{ github.workspace }}/keystores/authenticator_apk-keystore.jks" \ storePassword:"$STORE_PASSWORD" \ keyAlias:"bitwardenauthenticator" \ keyPassword:"$KEY_PASSWORD" - name: Upload to GitHub Artifacts - prod.aab if: ${{ matrix.variant == 'aab' }} uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0 with: name: com.bitwarden.authenticator.aab path: authenticator/build/outputs/bundle/release/com.bitwarden.authenticator.aab if-no-files-found: error - name: Upload to GitHub Artifacts - prod.apk if: ${{ matrix.variant == 'apk' }} uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0 with: name: com.bitwarden.authenticator.apk path: authenticator/build/outputs/apk/release/com.bitwarden.authenticator.apk if-no-files-found: error - name: Create checksum file for Release AAB if: ${{ matrix.variant == 'aab' }} run: | sha256sum "authenticator/build/outputs/bundle/release/com.bitwarden.authenticator.aab" \ > ./authenticator-android-aab-sha256.txt - name: Create checksum for release .apk artifact if: ${{ matrix.variant == 'apk' }} run: | sha256sum "authenticator/build/outputs/apk/release/com.bitwarden.authenticator.apk" \ > ./authenticator-android-apk-sha256.txt - name: Upload to GitHub Artifacts - prod.apk-sha256.txt if: ${{ matrix.variant == 'apk' }} uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0 with: name: authenticator-android-apk-sha256.txt path: ./authenticator-android-apk-sha256.txt if-no-files-found: error - name: Upload to GitHub Artifacts - prod.aab-sha256.txt if: ${{ matrix.variant == 'aab' }} uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0 with: name: authenticator-android-aab-sha256.txt path: ./authenticator-android-aab-sha256.txt if-no-files-found: error - name: Install Firebase app distribution plugin if: ${{ matrix.variant == 'aab' && env.DISTRIBUTE_TO_FIREBASE }} run: bundle exec fastlane add_plugin firebase_app_distribution - name: Distribute to Firebase - prod.aab if: ${{ matrix.variant == 'aab' && env.DISTRIBUTE_TO_FIREBASE }} env: FIREBASE_CREDS_PATH: ${{ github.workspace }}/secrets/authenticator_play_firebase-creds.json run: | bundle exec fastlane distributeAuthenticatorReleaseBundleToFirebase \ serviceCredentialsFile:"$FIREBASE_CREDS_PATH" - name: Publish to Play Store - prod.aab if: ${{ matrix.variant == 'aab' && env.PUBLISH_TO_PLAY_STORE }} env: PLAY_STORE_CREDS_FILE: ${{ github.workspace }}/secrets/authenticator_play_store-creds.json run: | bundle exec fastlane publishAuthenticatorReleaseToGooglePlayStore \ serviceCredentialsFile:"$PLAY_STORE_CREDS_FILE" \