adding GH actions file #1
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build and Deploy Next.js to GCP | |
on: | |
push: | |
branches: | |
- rewards-dashboard | |
- main | |
jobs: | |
build-and-deploy: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v2 | |
- name: Authenticate with Google Cloud | |
uses: google-github-actions/auth@v1 | |
with: | |
credentials_json: ${{ secrets.GCP_SA_KEY }} | |
- name: Set up Google Cloud SDK | |
uses: google-github-actions/setup-gcloud@v1 | |
with: | |
project_id: ${{ secrets.GCP_PROJECT_ID }} | |
- name: Install bun | |
uses: oven-sh/setup-bun@v1 | |
- name: Set up Node.js | |
uses: actions/setup-node@v2 | |
with: | |
node-version: "22" | |
- name: Install pnpm | |
run: npm install -g pnpm | |
- name: Install Doppler CLI | |
run: | | |
(curl -Ls --tlsv1.2 --proto "=https" --retry 3 https://cli.doppler.com/install.sh || wget -t 3 -qO- https://cli.doppler.com/install.sh) | sudo sh | |
- name: Set up Doppler | |
run: doppler configure set token ${{ secrets.DEVDEPLOY_DOPPLER_TOKEN }} | |
- name: Fetch secrets from Doppler and boot | |
run: doppler run -- npm run boot | |
env: | |
DOPPLER_TOKEN: ${{ secrets.DEVDEPLOY_DOPPLER_TOKEN }} | |
- name: Build Next.js app | |
working-directory: ./apps/rewards-dashboard | |
run: pnpm run build | |
# Step 11: Upload build output to GCS | |
- name: Upload build output to GCS | |
run: | | |
gsutil -m rsync -r -x "^\..*|README.md|gha-creds-.*\.json" ./apps/rewards-dashboard/out gs://${{ secrets.GCS_BUCKET_NAME }} | |
# Step 12: Set public read access to files | |
- name: Set public read access to files | |
run: | | |
gsutil iam ch allUsers:objectViewer gs://${{ secrets.GCS_BUCKET_NAME }} |