mirror of
https://github.com/ToolJet/ToolJet
synced 2026-04-21 13:37:28 +00:00
* Cloud Blocker bugfixes (#13160) * fix * minor email fixes * settings menu fix * fixes * Bugfixes/whitelabelling apis (#13180) * white-labelling apis * removed consoles logs * reverts * fixes for white-labelling * fixes * reverted breadcrumb changes (#13194) * fixes for getting public sso configurations * fix for enable signup on cloud * Cloud Trial and Banners (#13182) * Cloud Blocker bugfixes (#13160) * fix * minor email fixes * settings menu fix * fixes * Cloud Trial and Banners * revert * initial commit * Added website onboarding APIs * moved ai onboarding controller to auth module * ee banners * fix --------- Co-authored-by: Rohan Lahori <64496391+rohanlahori@users.noreply.github.com> Co-authored-by: gsmithun4 <gsmithun4@gmail.com> * Bugfixes/minor UI fixes-CLoud (#13203) * Bugfixes/UI bugs platform 1 (#13205) * cleanup * Audit logs fix * gitignore changes * postgrest configs removed * removed unused import * improvements * fix * improved startup logs * Platform cypress fix (#13192) * Cloud Blocker bugfixes (#13160) * fix * minor email fixes * settings menu fix * fixes * Bugfixes/whitelabelling apis (#13180) * white-labelling apis * removed consoles logs * reverts * fixes for white-labelling * fixes * Cypress fix * reverted breadcrumb changes (#13194) * cypress fix * title fix * fixes for getting public sso configurations --------- Co-authored-by: Rohan Lahori <64496391+rohanlahori@users.noreply.github.com> Co-authored-by: gsmithun4 <gsmithun4@gmail.com> * deployment fix * added interfaces and permissions * Bugfixes/lts 3.6 branch 1 platform (#13238) * fix * Licensing Banners Fixes Cloud and EE (#13241) * design: Adds license buttons to header * Refactor header actions * Cloud Blocker bugfixes (#13160) * fix * minor email fixes * settings menu fix * fixes * subscription page * fix banners --------- Co-authored-by: Nithin David Thomas <1277421+nithindavid@users.noreply.github.com> Co-authored-by: Rohan Lahori <64496391+rohanlahori@users.noreply.github.com> * fix for public apps * fix * CE Instance Signup bug (#13254) * CE Instance Signup bug * improvement * fix * Add WEBSITE_SIGNUP_URL to deployment environment variables * Add WEBSITE_SIGNUP_URL to environment variables for deployment * Super admin banner fix (#13262) * Git Sync Fixes (#13249) * git-sync module changes * git sync fixes * added app resource guard * git-sync fixes * removed require feature * fix * review comment changes * ypress fix * App logo fix inside app builder * fix for subpath cache * fix (#13274) * platform-cypress-fix (#13271) * git sync fixes (#13277) * fix * Add data-cy for new components (#13289) --------- Co-authored-by: Rohan Lahori <64496391+rohanlahori@users.noreply.github.com> Co-authored-by: Rudhra Deep Biswas <98055396+rudeUltra@users.noreply.github.com> Co-authored-by: Ajith KV <ajith.jaban@gmail.com> Co-authored-by: Nithin David Thomas <1277421+nithindavid@users.noreply.github.com> Co-authored-by: rohanlahori <rohanlahori99@gmail.com> Co-authored-by: Adish M <adish.madhu@gmail.com> Co-authored-by: Rudra deep Biswas <rudra21ultra@gmail.com>
133 lines
5.4 KiB
YAML
133 lines
5.4 KiB
YAML
name: Deploy to cloud frontend
|
|
|
|
on:
|
|
workflow_dispatch:
|
|
inputs:
|
|
branch:
|
|
description: 'Git branch to deploy (must start with "lts-", e.g., lts-3.6)'
|
|
required: true
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: ✅ Check user authorization
|
|
run: |
|
|
allowed_user1=${{ secrets.ALLOWED_USER1_USERNAME }}
|
|
allowed_user2=${{ secrets.ALLOWED_USER2_USERNAME }}
|
|
allowed_user3=${{ secrets.ALLOWED_USER3_USERNAME }}
|
|
|
|
if [[ "${{ github.actor }}" != "$allowed_user1" && \
|
|
"${{ github.actor }}" != "$allowed_user2" && \
|
|
"${{ github.actor }}" != "$allowed_user3" ]]; then
|
|
echo "❌ User '${{ github.actor }}' is not authorized to trigger this workflow."
|
|
exit 1
|
|
else
|
|
echo "✅ User '${{ github.actor }}' is authorized."
|
|
fi
|
|
|
|
- name: 📥 Manual Git checkout with submodules
|
|
run: |
|
|
set -e
|
|
|
|
BRANCH="${{ github.event.inputs.branch }}"
|
|
REPO="https://x-access-token:${{ secrets.CUSTOM_GITHUB_TOKEN }}@github.com/${{ github.repository }}"
|
|
|
|
git config --global url."https://x-access-token:${{ secrets.CUSTOM_GITHUB_TOKEN }}@github.com/".insteadOf "https://github.com/"
|
|
git config --global http.version HTTP/1.1
|
|
git config --global http.postBuffer 524288000
|
|
|
|
echo "👉 Cloning $REPO (branch: $BRANCH)"
|
|
git clone --recurse-submodules --depth=1 --branch "$BRANCH" "$REPO" repo
|
|
cd repo
|
|
|
|
echo "🔁 Updating submodules"
|
|
git submodule update --init --recursive
|
|
|
|
echo "🔀 Attempting to checkout '$BRANCH' in each submodule and validating"
|
|
|
|
BRANCH="$BRANCH" git submodule foreach --recursive bash -c '
|
|
name="$sm_path"
|
|
echo ""
|
|
echo "Entering '\''$name'\''"
|
|
echo "↪ $name: trying to checkout branch '\''$BRANCH'\''"
|
|
|
|
if git ls-remote --exit-code --heads origin "$BRANCH" >/dev/null; then
|
|
git fetch origin "$BRANCH:$BRANCH" || {
|
|
echo "❌ $name: fetch failed for $BRANCH"
|
|
exit 1
|
|
}
|
|
|
|
PREV=$(git rev-parse --short HEAD || echo "unknown")
|
|
git checkout "$BRANCH" || {
|
|
echo "❌ $name: checkout failed for $BRANCH"
|
|
exit 1
|
|
}
|
|
|
|
echo "Previous HEAD position was $PREV: $(git log -1 --pretty=%s || echo 'unknown')"
|
|
echo "✅ $name: checked out branch $BRANCH"
|
|
else
|
|
echo "⚠️ $name: branch '$BRANCH' not found on origin. Falling back to 'main'"
|
|
PREV=$(git rev-parse --short HEAD || echo "unknown")
|
|
git checkout main && git pull origin main || {
|
|
echo "❌ $name: fallback to main failed"
|
|
exit 1
|
|
}
|
|
echo "Previous HEAD position was $PREV: $(git log -1 --pretty=%s || echo 'unknown')"
|
|
echo "✅ $name: now on branch main"
|
|
fi
|
|
|
|
CURRENT=$(git rev-parse --abbrev-ref HEAD)
|
|
echo "🔎 $name: current branch = $CURRENT"
|
|
if [ "$CURRENT" != "$BRANCH" ] && [ "$CURRENT" != "main" ]; then
|
|
echo "❌ $name: unexpected branch state — wanted '$BRANCH' or fallback 'main', got '$CURRENT'"
|
|
exit 1
|
|
fi
|
|
'
|
|
|
|
- name: 🧰 Setup Node.js
|
|
uses: actions/setup-node@v2
|
|
with:
|
|
node-version: 22.15.1
|
|
|
|
- name: 📦 Install dependencies
|
|
run: npm install
|
|
working-directory: repo
|
|
|
|
- name: 🛠️ Build the project
|
|
run: npm run build:plugins:prod && npm run build:frontend
|
|
working-directory: repo
|
|
env:
|
|
GOOGLE_MAPS_API_KEY: ${{ secrets.CLOUD_GOOGLE_MAPS_API_KEY }}
|
|
NODE_ENV: ${{ secrets.CLOUD_NODE_ENV }}
|
|
NODE_OPTIONS: ${{ secrets.CLOUD_NODE_OPTIONS }}
|
|
SENTRY_AUTH_TOKEN: ${{ secrets.CLOUD_SENTRY_AUTH_TOKEN }}
|
|
SENTRY_ORG: ${{ secrets.CLOUD_SENTRY_ORG }}
|
|
SENTRY_PROJECT: ${{ secrets.CLOUD_SENTRY_PROJECT }}
|
|
SERVE_CLIENT: ${{ secrets.CLOUD_SERVE_CLIENT }}
|
|
SERVER_IP: ${{ secrets.CLOUD_SERVER_IP }}
|
|
TJDB_SQL_MODE_DISABLE: ${{ secrets.CLOUD_TJDB_SQL_MODE_DISABLE }}
|
|
TOOLJET_SERVER_URL: ${{ secrets.CLOUD_TOOLJET_SERVER_URL }}
|
|
TOOLJET_EDITION: cloud
|
|
WEBSITE_SIGNUP_URL: https://website-stage.tooljet.ai/ai-create-account
|
|
|
|
- name: 🚀 Deploy to Netlify
|
|
run: |
|
|
npm install -g netlify-cli
|
|
netlify deploy --prod --dir=frontend/build --auth=$NETLIFY_AUTH_TOKEN --site=${{ secrets.CLOUD_NETLIFY_SITE_ID }}
|
|
working-directory: repo
|
|
env:
|
|
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
|
GOOGLE_MAPS_API_KEY: ${{ secrets.CLOUD_GOOGLE_MAPS_API_KEY }}
|
|
NODE_ENV: ${{ secrets.CLOUD_NODE_ENV }}
|
|
NODE_OPTIONS: ${{ secrets.CLOUD_NODE_OPTIONS }}
|
|
SENTRY_AUTH_TOKEN: ${{ secrets.CLOUD_SENTRY_AUTH_TOKEN }}
|
|
SENTRY_ORG: ${{ secrets.CLOUD_SENTRY_ORG }}
|
|
SENTRY_PROJECT: ${{ secrets.CLOUD_SENTRY_PROJECT }}
|
|
SERVE_CLIENT: ${{ secrets.CLOUD_SERVE_CLIENT }}
|
|
SERVER_IP: ${{ secrets.CLOUD_SERVER_IP }}
|
|
TJDB_SQL_MODE_DISABLE: ${{ secrets.CLOUD_TJDB_SQL_MODE_DISABLE }}
|
|
TOOLJET_SERVER_URL: ${{ secrets.CLOUD_TOOLJET_SERVER_URL }}
|
|
WEBSITE_SIGNUP_URL: https://website-stage.tooljet.ai/ai-create-account
|
|
TOOLJET_EDITION: cloud
|