Skip to content

Sandbox Phase 1 - Character filters #67

Sandbox Phase 1 - Character filters

Sandbox Phase 1 - Character filters #67

Workflow file for this run

name: Upload Image to Docker Hub & Deploy to Dev
on:
push:
branches:
- workflow #develop
pull_request:
types:
- closed
branches:
- develop
jobs:
docker:
if: (github.event_name == 'push' ) || (github.event.pull_request.merged == true)
runs-on: ubuntu-latest
steps:
-
name: Checkout code
uses: actions/checkout@v4
-
name: Load env from file
run: |
echo "Loading env vars from .env file"
while IFS='=' read -r key value
do
key=$(echo $key | tr '.' '_')
echo "$key=$value" >> $GITHUB_ENV
done < conf/.env.CI.dev
echo "Done"
#- name: Setup git-crypt
#run: |
#sudo apt-get update
#sudo apt-get install -y git-crypt
#- name: Decrypt secrets
#env:
#GIT_CRYPT_KEY: ${{ secrets.GIT_CRYPT_KEY }}
#run: |
#echo "$GIT_CRYPT_KEY" | base64 --decode > git_crypt.key
#git-crypt unlock git_crypt.key
#rm git_crypt.key
-
name: Set up JDK 21
uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: 21
- name: Setup Gradle 8.8
uses: gradle/actions/setup-gradle@v3
with:
gradle-version: 8.8
-
name: Cache Gradle packages
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle') }}
restore-keys: ${{ runner.os }}-gradle
-
name: Build
run: |
./gradlew :${{ env.MICROSERVICE_DEPLOY }}:build -PMICROSERVICE_VERSION=${{ env.MICROSERVICE_VERSION }}
cp ${{ env.MICROSERVICE_DEPLOY }}/build/libs/${{ env.MICROSERVICE_DEPLOY}}-${{ env.MICROSERVICE_VERSION }}.jar ${GITHUB_WORKSPACE}/${{ env.MICROSERVICE_DEPLOY }}
-
name: Set up QEMU
uses: docker/setup-qemu-action@v3
-
name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
-
name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
-
name: Build and push
uses: docker/build-push-action@v5
with:
context: ${{ env.MICROSERVICE_DEPLOY }}
push: true
tags: itacademybcn/itachallenges:${{ env.MICROSERVICE_DEPLOY}}-${{ env.MICROSERVICE_VERSION }}
deploy:
if: (github.event_name == 'push' ) || (github.event.pull_request.merged == true)
needs: docker
runs-on: ubuntu-latest
steps:
-
name: Checkout code
uses: actions/checkout@v4
-
name: Load env from file
run: |
echo "Loading env vars from .env file"
while IFS='=' read -r key value
do
key=$(echo $key | tr '.' '_')
echo "$key=$value" >> $GITHUB_ENV
echo "$key=$value"
done < conf/.env.CI.dev
echo "Done"
-
name: Execute SSH
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST_URL }}
username: ${{ secrets.SSH_USERNAME }}
key: ${{ secrets.SSH_KEY }}
script: |
./deploy_backend_dev.sh ${{ env.MICROSERVICE_DEPLOY }} ${{ env.MICROSERVICE_VERSION }}