Skip to content

Automated Firebase Functions deployment with Service Account Key using GitHub Actions

License

Notifications You must be signed in to change notification settings

kburakengin/firebase-functions-deploy

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace
 
 

Repository files navigation

Deploy Firebase Functions with GitHub Actions using Service Account Credentials 🚀

This repository provides a GitHub Actions workflow that allows you to deploy your Firebase Cloud Functions using your service account credentials.

Usage

Deploy on each production branch push

To deploy on each push to the production branch, add the following code to your workflow file:

name: Deploy Firebase Functions

on:
  push:
    branches:
      - production
      - staging
    # Optionally configure to run only for specific files. For example:
    # paths:
    # - "website/**"
env:
  PROJECT_ID: your-Firebase-project-ID # The ID of your Firebase/GCP project

jobs:
  deploy_live_website:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2
      # Add any build steps here. For example:
      # - run: npm ci && npm run build
      - uses: kburakengin/[email protected]
        with:
          serviceAccountKey: "${{ secrets.DEPLOY_SERVICE_ACCOUNT_KEY }}"
          projectId: "${{ env.PROJECT_ID }}"
          functionNames: "myFunction1,myFunction2" # The name of the functions

Options

You can configure the action-functions-deploy GitHub Action using the following options:

Parameter Type Required Description
serviceAccountKey string Yes This is a service account JSON key. The easiest way to set it up is to run firebase init hosting:github. However, it can also be created manually. It's important to store this token as an encrypted secret to prevent unintended access to your Firebase project. Set it in the "Secrets" area of your repository settings and reference it in the workflow file. Example: serviceAccountKey: "${{ secrets.DEPLOY_SERVICE_ACCOUNT_KEY }}"
projectId string No The Firebase project that contains the Hosting site to which you want to deploy. If left blank, you need to check in a .firebaserc file so that the Firebase CLI knows which Firebase project to use.
functionNames string No The function names you have created in your project. Exp. myFunction1. exports.myFunction1 = "". If not provided deploys all the functions available.
firebaseToolsVersion string No The version of firebase-tools to use. If not specified, defaults to latest.

Forked from aronep6/action-functions-deploy

This GitHub Action was forked from aronep6/action-functions-deploy. I have added specific function name functionality which is being required a lot.

The logic is all the same. It deploys firebase functions with specific function names if needed.

About

Automated Firebase Functions deployment with Service Account Key using GitHub Actions

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 100.0%