Build source code and send to Capgo #2417
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 source code and send to Capgo | |
on: | |
push: | |
tags: | |
- '*' | |
jobs: | |
deploy: | |
runs-on: ubuntu-latest | |
name: "Build code and release" | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Setup bun | |
uses: oven-sh/setup-bun@v1.1.1 | |
with: | |
bun-version: latest | |
- name: Install dependencies | |
run: bun install | |
- name: Lint | |
id: lint_code | |
run: bun lint && bun lint-backend | |
- name: Build PROD | |
id: build_code | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
run: bun mobile | |
env: | |
VITE_VAPID_KEY: ${{ secrets.VITE_VAPID_KEY }} | |
VITE_FIREBASE_CONFIG: ${{ secrets.VITE_FIREBASE_CONFIG }} | |
- name: Build ALPHA | |
id: build_code_alpha | |
if: ${{ contains(github.ref, '-alpha.') }} | |
run: bun dev-mobile | |
env: | |
VITE_VAPID_KEY: ${{ secrets.VITE_VAPID_KEY }} | |
VITE_FIREBASE_CONFIG: ${{ secrets.VITE_FIREBASE_CONFIG }} | |
- name: Install Supabase CLI | |
uses: supabase/setup-cli@v1 | |
with: | |
version: 1.176.10 | |
- name: Set env PROD | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
run: echo "SUPABASE_DB_PASSWORD=${{ secrets.SUPABASE_DB_PASS }}" >> $GITHUB_ENV | |
- name: Set env ALPHA | |
if: ${{ contains(github.ref, '-alpha.') }} | |
run: echo "SUPABASE_DB_PASSWORD=${{ secrets.SUPABASE_DB_PASS_ALPHA }}" >> $GITHUB_ENV | |
- name: 🍜 Prepare Supabase PROD | |
run: supabase link --project-ref xvwzpoazmxkqosrdewyv | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
env: | |
SUPABASE_ACCESS_TOKEN: ${{ secrets.SUPABASE_TOKEN }} | |
- name: 🍜 Prepare Supabase ALPHA | |
run: supabase link --project-ref aucsybvnhavogdmzwtcw | |
if: ${{ contains(github.ref, '-alpha.') }} | |
env: | |
SUPABASE_ACCESS_TOKEN: ${{ secrets.SUPABASE_TOKEN }} | |
# - name: 🚨 Seed Supabase ALPHA | |
# if: ${{ contains(github.ref, '-alpha.') }} | |
# run: supabase db reset --linked | |
- name: 🦤 Apply Supabase Migrations | |
run: supabase db push --include-all | |
- name: 🆙 Update functions | |
id: update_functions_prod | |
env: | |
SUPABASE_ACCESS_TOKEN: ${{ secrets.SUPABASE_TOKEN }} | |
run: supabase functions deploy | |
- name: Deploy CF Worker | |
run: bunx wrangler@latest deploy --name capgo_api | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
env: | |
CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_API_TOKEN }} | |
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | |
- name: Deploy CF Worker ALPHA | |
run: bunx wrangler@latest deploy --name capgo_api-alpha | |
if: ${{ contains(github.ref, '-alpha.') }} | |
env: | |
CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_API_TOKEN }} | |
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | |
- name: Publish CF webapp PROD | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
run: bunx wrangler@latest pages deploy dist --project-name capgo-webapp --branch main | |
env: | |
CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_API_TOKEN }} | |
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | |
- name: Publish CF webapp ALPHA | |
if: ${{ contains(github.ref, '-alpha.') }} | |
run: bunx wrangler@latest pages deploy dist --project-name capgo-webapp-alpha --branch main | |
env: | |
CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_API_TOKEN }} | |
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | |
- name: Create Release ALPHA | |
if: ${{ contains(github.ref, '-alpha.') }} | |
id: create_release_alpha | |
run: bun x @capgo/cli@latest bundle upload -a ${{ secrets.CAPGO_TOKEN }} -c alpha | |
- name: Create Release PROD | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
id: create_release_prod | |
run: bun x @capgo/cli@latest bundle upload -a ${{ secrets.CAPGO_TOKEN }} -c production | |
- name: Create Sourcemap Sentry | |
run: bun run cf-build | |
- name: Create Sentry ALPHA | |
if: ${{ contains(github.ref, '-alpha.') }} | |
uses: getsentry/action-release@v1 | |
env: | |
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} | |
SENTRY_ORG: ${{ secrets.SENTRY_ORG }} | |
SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }} | |
with: | |
environment: staging | |
sourcemaps: dist_cf | |
version: ${{ github.ref }} | |
- name: Create Sentry release PROD | |
if: ${{ !contains(github.ref, '-alpha.') }} | |
uses: getsentry/action-release@v1 | |
env: | |
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} | |
SENTRY_ORG: ${{ secrets.SENTRY_ORG }} | |
SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }} | |
with: | |
environment: production | |
sourcemaps: dist_cf | |
version: ${{ github.ref }} | |
build_android: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Setup bun | |
uses: oven-sh/setup-bun@v1.1.1 | |
with: | |
bun-version: latest | |
- name: Install dependencies | |
id: install_code | |
run: bun install | |
- name: Build | |
id: build_code | |
run: bun mobile | |
- name: Sync | |
id: sync_code | |
run: bun x cap sync | |
- name: Setup java | |
uses: actions/setup-java@v4 | |
with: | |
distribution: 'zulu' | |
java-version: '17' | |
- name: Decode Keystore File | |
uses: timheuer/base64-to-file@v1 | |
id: android_keystore | |
with: | |
fileName: "android_keystore.keystore" | |
encodedString: ${{ secrets.ANDROID_KEYSTORE_FILE }} | |
- name: Decode Google Play Confi File | |
uses: timheuer/base64-to-file@v1 | |
id: service_account_json_file | |
with: | |
fileName: "serviceAccount.json" | |
encodedString: ${{ secrets.PLAY_CONFIG_JSON }} | |
- uses: actions/cache@v4 | |
with: | |
path: | | |
~/android/.gradle/* | |
~/android/gradle/wrapper/* | |
key: ${{ runner.os }}-gradle-${{ hashFiles('android/.gradle*', 'android/gradle/wrapper/gradle-wrapper.properties') }} | |
restore-keys: | | |
${{ runner.os }}-gradle- | |
- uses: ruby/setup-ruby@v1 | |
with: | |
ruby-version: '3.0' | |
bundler-cache: true | |
- uses: maierj/fastlane-action@v3.1.0 | |
env: | |
KEYSTORE_PATH: ${{ steps.android_keystore.outputs.filePath }} | |
ANDROID_JSON_KEY_FILE: ${{ steps.service_account_json_file.outputs.filePath }} | |
DEVELOPER_PACKAGE_NAME: ${{ secrets.DEVELOPER_PACKAGE_NAME }} | |
KEYSTORE_KEY_ALIAS: ${{ secrets.KEYSTORE_KEY_ALIAS }} | |
KEYSTORE_KEY_PASSWORD: ${{ secrets.KEYSTORE_KEY_PASSWORD }} | |
KEYSTORE_STORE_PASSWORD: ${{ secrets.KEYSTORE_STORE_PASSWORD }} | |
with: | |
lane: android beta | |
- name: Upload release bundle | |
uses: actions/upload-artifact@v4 | |
with: | |
name: android-release | |
path: ./android/app/build/outputs/bundle/release/app-release.aab | |
retention-days: 10 | |
# build_ios: | |
# runs-on: macOS-latest | |
# steps: | |
# - uses: actions/checkout@v4 | |
# - uses: pnpm/action-setup@v2 | |
# with: | |
# version: 8 | |
# - name: Use Node.js | |
# uses: actions/setup-node@v3 | |
# with: | |
# node-version: 18 | |
# cache: 'pnpm' | |
# - name: Install dependencies | |
# id: install_code | |
# run: pnpm install --frozen-lockfile | |
# - uses: actions/cache@v3 | |
# with: | |
# path: ios/App/Pods | |
# key: ${{ runner.os }}-pods-${{ hashFiles('**/Podfile.lock') }} | |
# restore-keys: | | |
# ${{ runner.os }}-pods- | |
# - name: Build | |
# id: build_code | |
# run: pnpm mobile | |
# - name: Sync | |
# id: sync_code | |
# run: bun x @capacitor/cli cap sync | |
# - uses: ruby/setup-ruby@v1 | |
# with: | |
# ruby-version: '2.7.2' | |
# - uses: maierj/fastlane-action@v2.3.0 | |
# env: | |
# DEVELOPER_APP_IDENTIFIER: ${{ secrets.DEVELOPER_APP_IDENTIFIER }} | |
# DEVELOPER_APP_ID: ${{ secrets.DEVELOPER_APP_ID }} | |
# PROVISIONING_PROFILE_SPECIFIER: match AppStore ${{ secrets.DEVELOPER_APP_IDENTIFIER }} | |
# TEMP_KEYCHAIN_USER: ${{ secrets.TEMP_KEYCHAIN_USER }} | |
# TEMP_KEYCHAIN_PASSWORD: ${{ secrets.TEMP_KEYCHAIN_PASSWORD }} | |
# APPLE_ISSUER_ID: ${{ secrets.APPSTORE_ISSUER_ID }} | |
# APPLE_KEY_ID: ${{ secrets.APPSTORE_KEY_ID }} | |
# APPLE_KEY_CONTENT: ${{ secrets.APPSTORE_PRIVATE_KEY }} | |
# CERTIFICATE_STORE_URL: https://github.com/${{ secrets.CERTIFICATE_STORE_REPO }}.git | |
# GIT_USERNAME: ${{ secrets.GIT_USERNAME }} | |
# GIT_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN }} | |
# FASTLANE_APPLE_ID: ${{ secrets.FASTLANE_APPLE_ID }} | |
# MATCH_USERNAME: ${{ secrets.FASTLANE_APPLE_ID }} | |
# MATCH_PASSWORD: ${{ secrets.MATCH_PASSWORD }} | |
# APP_STORE_CONNECT_TEAM_ID: ${{ secrets.APP_STORE_CONNECT_TEAM_ID }} | |
# DEVELOPER_PORTAL_TEAM_ID: ${{ secrets.DEVELOPER_PORTAL_TEAM_ID }} | |
# with: | |
# lane: closed_beta | |
# # subdirectory: 'ios' | |
# - name: Upload release bundle | |
# uses: actions/upload-artifact@v3 | |
# with: | |
# name: ios-release | |
# path: ./App.ipa | |
# retention-days: 10 |