Merge branch 'preview' of https://github.com/makeplane/plane into cho… #29
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: Feature Preview | |
on: | |
workflow_dispatch: | |
inputs: | |
web-build: | |
required: false | |
description: "Build Web" | |
type: boolean | |
default: true | |
space-build: | |
required: false | |
description: "Build Space" | |
type: boolean | |
default: false | |
admin-build: | |
required: false | |
description: "Build Admin" | |
type: boolean | |
default: false | |
admin-build: | |
required: false | |
description: 'Build Admin' | |
type: boolean | |
default: false | |
env: | |
BUILD_WEB: ${{ github.event.inputs.web-build }} | |
BUILD_SPACE: ${{ github.event.inputs.space-build }} | |
BUILD_ADMIN: ${{ github.event.inputs.admin-build }} | |
jobs: | |
setup-feature-build: | |
name: Feature Build Setup | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
run: | | |
echo "BUILD_WEB=$BUILD_WEB" | |
echo "BUILD_SPACE=$BUILD_SPACE" | |
echo "BUILD_ADMIN=$BUILD_ADMIN" | |
outputs: | |
web-build: ${{ env.BUILD_WEB}} | |
space-build: ${{env.BUILD_SPACE}} | |
admin-build: ${{env.BUILD_ADMIN}} | |
feature-build-web: | |
if: ${{ needs.setup-feature-build.outputs.web-build == 'true' }} | |
needs: setup-feature-build | |
name: Feature Build Web | |
runs-on: ubuntu-latest | |
env: | |
AWS_ACCESS_KEY_ID: ${{ vars.FEATURE_PREVIEW_AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.FEATURE_PREVIEW_AWS_SECRET_ACCESS_KEY }} | |
AWS_BUCKET: ${{ vars.FEATURE_PREVIEW_AWS_BUCKET }} | |
NEXT_PUBLIC_API_BASE_URL: ${{ vars.FEATURE_PREVIEW_NEXT_PUBLIC_API_BASE_URL }} | |
steps: | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "18" | |
- name: Install AWS cli | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y python3-pip | |
pip3 install awscli | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
path: plane | |
- name: Install Dependencies | |
run: | | |
cd $GITHUB_WORKSPACE/plane | |
yarn install | |
- name: Build Web | |
id: build-web | |
run: | | |
cd $GITHUB_WORKSPACE/plane | |
yarn build --filter=web | |
cd $GITHUB_WORKSPACE | |
TAR_NAME="web.tar.gz" | |
tar -czf $TAR_NAME ./plane | |
FILE_EXPIRY=$(date -u -d "+2 days" +"%Y-%m-%dT%H:%M:%SZ") | |
aws s3 cp $TAR_NAME s3://${{ env.AWS_BUCKET }}/${{github.sha}}/$TAR_NAME --expires $FILE_EXPIRY | |
feature-build-space: | |
if: ${{ needs.setup-feature-build.outputs.space-build == 'true' }} | |
needs: setup-feature-build | |
name: Feature Build Space | |
runs-on: ubuntu-latest | |
env: | |
AWS_ACCESS_KEY_ID: ${{ vars.FEATURE_PREVIEW_AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.FEATURE_PREVIEW_AWS_SECRET_ACCESS_KEY }} | |
AWS_BUCKET: ${{ vars.FEATURE_PREVIEW_AWS_BUCKET }} | |
NEXT_PUBLIC_SPACE_BASE_PATH: "/spaces" | |
NEXT_PUBLIC_API_BASE_URL: ${{ vars.FEATURE_PREVIEW_NEXT_PUBLIC_API_BASE_URL }} | |
outputs: | |
do-build: ${{ needs.setup-feature-build.outputs.space-build }} | |
s3-url: ${{ steps.build-space.outputs.S3_PRESIGNED_URL }} | |
steps: | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "18" | |
- name: Install AWS cli | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y python3-pip | |
pip3 install awscli | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
path: plane | |
- name: Install Dependencies | |
run: | | |
cd $GITHUB_WORKSPACE/plane | |
yarn install | |
- name: Build Space | |
id: build-space | |
run: | | |
cd $GITHUB_WORKSPACE/plane | |
yarn build --filter=space | |
cd $GITHUB_WORKSPACE | |
TAR_NAME="space.tar.gz" | |
tar -czf $TAR_NAME ./plane | |
FILE_EXPIRY=$(date -u -d "+2 days" +"%Y-%m-%dT%H:%M:%SZ") | |
aws s3 cp $TAR_NAME s3://${{ env.AWS_BUCKET }}/${{github.sha}}/$TAR_NAME --expires $FILE_EXPIRY | |
feature-build-admin: | |
if: ${{ needs.setup-feature-build.outputs.admin-build == 'true' }} | |
needs: setup-feature-build | |
name: Feature Build Admin | |
runs-on: ubuntu-latest | |
env: | |
AWS_ACCESS_KEY_ID: ${{ vars.FEATURE_PREVIEW_AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.FEATURE_PREVIEW_AWS_SECRET_ACCESS_KEY }} | |
AWS_BUCKET: ${{ vars.FEATURE_PREVIEW_AWS_BUCKET }} | |
NEXT_PUBLIC_ADMIN_BASE_PATH: "/god-mode" | |
NEXT_PUBLIC_API_BASE_URL: ${{ vars.FEATURE_PREVIEW_NEXT_PUBLIC_API_BASE_URL }} | |
outputs: | |
do-build: ${{ needs.setup-feature-build.outputs.admin-build }} | |
s3-url: ${{ steps.build-admin.outputs.S3_PRESIGNED_URL }} | |
steps: | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "18" | |
- name: Install AWS cli | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y python3-pip | |
pip3 install awscli | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
path: plane | |
- name: Install Dependencies | |
run: | | |
cd $GITHUB_WORKSPACE/plane | |
yarn install | |
- name: Build Admin | |
id: build-admin | |
run: | | |
cd $GITHUB_WORKSPACE/plane | |
yarn build --filter=admin | |
cd $GITHUB_WORKSPACE | |
TAR_NAME="admin.tar.gz" | |
tar -czf $TAR_NAME ./plane | |
FILE_EXPIRY=$(date -u -d "+2 days" +"%Y-%m-%dT%H:%M:%SZ") | |
aws s3 cp $TAR_NAME s3://${{ env.AWS_BUCKET }}/${{github.sha}}/$TAR_NAME --expires $FILE_EXPIRY | |
feature-deploy: | |
if: ${{ always() && (needs.setup-feature-build.outputs.web-build == 'true' || needs.setup-feature-build.outputs.space-build == 'true' || needs.setup-feature-build.outputs.admin-build == 'true') }} | |
needs: | |
[ | |
setup-feature-build, | |
feature-build-web, | |
feature-build-space, | |
feature-build-admin, | |
] | |
name: Feature Deploy | |
runs-on: ubuntu-latest | |
env: | |
AWS_ACCESS_KEY_ID: ${{ vars.FEATURE_PREVIEW_AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.FEATURE_PREVIEW_AWS_SECRET_ACCESS_KEY }} | |
AWS_BUCKET: ${{ vars.FEATURE_PREVIEW_AWS_BUCKET }} | |
KUBE_CONFIG_FILE: ${{ secrets.FEATURE_PREVIEW_KUBE_CONFIG }} | |
steps: | |
- name: Install AWS cli | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y python3-pip | |
pip3 install awscli | |
- name: Tailscale | |
uses: tailscale/github-action@v2 | |
with: | |
oauth-client-id: ${{ secrets.TAILSCALE_OAUTH_CLIENT_ID }} | |
oauth-secret: ${{ secrets.TAILSCALE_OAUTH_SECRET }} | |
tags: tag:ci | |
- name: Kubectl Setup | |
run: | | |
curl -LO "https://dl.k8s.io/release/${{ vars.FEATURE_PREVIEW_KUBE_VERSION }}/bin/linux/amd64/kubectl" | |
chmod +x kubectl | |
mkdir -p ~/.kube | |
echo "$KUBE_CONFIG_FILE" > ~/.kube/config | |
chmod 600 ~/.kube/config | |
- name: HELM Setup | |
run: | | |
curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | |
chmod 700 get_helm.sh | |
./get_helm.sh | |
- name: App Deploy | |
run: | | |
WEB_S3_URL="" | |
if [ ${{ env.BUILD_WEB }} == true ]; then | |
WEB_S3_URL=$(aws s3 presign s3://${{ vars.FEATURE_PREVIEW_AWS_BUCKET }}/${{github.sha}}/web.tar.gz --expires-in 3600) | |
fi | |
SPACE_S3_URL="" | |
if [ ${{ env.BUILD_SPACE }} == true ]; then | |
SPACE_S3_URL=$(aws s3 presign s3://${{ vars.FEATURE_PREVIEW_AWS_BUCKET }}/${{github.sha}}/space.tar.gz --expires-in 3600) | |
fi | |
ADMIN_S3_URL="" | |
if [ ${{ env.BUILD_ADMIN }} == true ]; then | |
ADMIN_S3_URL=$(aws s3 presign s3://${{ vars.FEATURE_PREVIEW_AWS_BUCKET }}/${{github.sha}}/admin.tar.gz --expires-in 3600) | |
fi | |
if [ ${{ env.BUILD_WEB }} == true ] || [ ${{ env.BUILD_SPACE }} == true ] || [ ${{ env.BUILD_ADMIN }} == true ]; then | |
helm --kube-insecure-skip-tls-verify repo add feature-preview ${{ vars.FEATURE_PREVIEW_HELM_CHART_URL }} | |
APP_NAMESPACE="${{ vars.FEATURE_PREVIEW_NAMESPACE }}" | |
DEPLOY_SCRIPT_URL="${{ vars.FEATURE_PREVIEW_DEPLOY_SCRIPT_URL }}" | |
METADATA=$(helm --kube-insecure-skip-tls-verify install feature-preview/${{ vars.FEATURE_PREVIEW_HELM_CHART_NAME }} \ | |
--generate-name \ | |
--namespace $APP_NAMESPACE \ | |
--set ingress.primaryDomain=${{vars.FEATURE_PREVIEW_PRIMARY_DOMAIN || 'feature.plane.tools' }} \ | |
--set web.image=${{vars.FEATURE_PREVIEW_DOCKER_BASE}} \ | |
--set web.enabled=${{ env.BUILD_WEB || false }} \ | |
--set web.artifact_url=$WEB_S3_URL \ | |
--set space.image=${{vars.FEATURE_PREVIEW_DOCKER_BASE}} \ | |
--set space.enabled=${{ env.BUILD_SPACE || false }} \ | |
--set space.artifact_url=$SPACE_S3_URL \ | |
--set admin.image=${{vars.FEATURE_PREVIEW_DOCKER_BASE}} \ | |
--set admin.enabled=${{ env.BUILD_ADMIN || false }} \ | |
--set admin.artifact_url=$ADMIN_S3_URL \ | |
--set shared_config.deploy_script_url=$DEPLOY_SCRIPT_URL \ | |
--set shared_config.api_base_url=${{vars.FEATURE_PREVIEW_NEXT_PUBLIC_API_BASE_URL}} \ | |
--output json \ | |
--timeout 1000s) | |
APP_NAME=$(echo $METADATA | jq -r '.name') | |
INGRESS_HOSTNAME=$(kubectl get ingress -n feature-builds --insecure-skip-tls-verify \ | |
-o jsonpath='{.items[?(@.metadata.annotations.meta\.helm\.sh\/release-name=="'$APP_NAME'")]}' | \ | |
jq -r '.spec.rules[0].host') | |
echo "****************************************" | |
echo "APP NAME ::: $APP_NAME" | |
echo "INGRESS HOSTNAME ::: $INGRESS_HOSTNAME" | |
echo "****************************************" | |
fi |