Skip to content

Firebase Deploy Dev #29

Firebase Deploy Dev

Firebase Deploy Dev #29

name: Firebase Deploy Dev
on:
workflow_dispatch:
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}-Dev
cancel-in-progress: true
jobs:
deploy:
timeout-minutes: 30
runs-on: ubuntu-latest
permissions: # for KoheiKanagu/composite-actions/setup-firebase-cli@main
id-token: write
contents: read
steps:
### Setup ###
- uses: actions/checkout@v4
- name: Setup Firebase CLI
uses: KoheiKanagu/composite-actions/setup-firebase-cli@main
with:
workload_identity_provider: ${{ vars.WORKLOAD_IDENTITY_PROVIDER_DEV }}
service_account: ${{ vars.SERVICE_ACCOUNT_DEV }}
- run: |
firebase use dev --debug
- name: Copy Remote Config Template
run: |
cp firebase/remoteconfig/template.dev.json firebase/remoteconfig/template.json
- name: Install dependencies
run: npm ci
working-directory: firebase/functions
### Deploy ###
- name: Deploy Mail Templates
working-directory: firebase/functions
run: |
# https://github.com/firebase/firebase-admin-node/issues/1377
# Workaround for the issue above
echo ${{ secrets.FIREBASE_ADMIN_SDK_SERVICE_ACCOUNT_DEV }} | base64 --decode > service-account.json
# GOOGLE_APPLICATION_CREDENTIALS is only used in the current shell
export GOOGLE_APPLICATION_CREDENTIALS=$GITHUB_WORKSPACE/firebase/functions/service-account.json
npx tsx scripts/set-mail-templates.ts --force
npx tsx scripts/set-service-status-up.ts --force
- name: Firebase Deploy
run: |
firebase deploy --force --except extensions
### Cleanup ###
- name: Cleanup
if: always()
run: |
rm -f service-account.json