misc(ci/cd): Update with AI Feature #51
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: Deploy xyzuan-api-v2 Development Build | |
on: | |
push: | |
branches: | |
- dev | |
jobs: | |
test: | |
name: Run Treaty Tests | |
runs-on: self-hosted | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Initialize Bun Environtment | |
uses: oven-sh/setup-bun@v2 | |
- name: Declaring some Global Environtment vars | |
run: | | |
echo "PORT=4031" >> $GITHUB_ENV | |
echo "DOMAIN=localhost" >> $GITHUB_ENV | |
echo "NODE_ENV=dev" >> $GITHUB_ENV | |
echo "PASSWORD_PEPPER=${{ secrets.PASSWORD_PEPPER }}" >> $GITHUB_ENV | |
echo "DATABASE_URL=${{ secrets.DATABASE_URL_DEV }}" >> $GITHUB_ENV | |
echo "GOOGLE_CLIENT_ID=${{ secrets.GOOGLE_CLIENT_ID }}" >> $GITHUB_ENV | |
echo "GOOGLE_CLIENT_SECRET=${{ secrets.GOOGLE_CLIENT_SECRET }}" >> $GITHUB_ENV | |
echo "GITHUB_CLIENT_ID=${{ secrets.GH_CLIENT_ID }}" >> $GITHUB_ENV | |
echo "GITHUB_CLIENT_SECRET=${{ secrets.GH_CLIENT_SECRET }}" >> $GITHUB_ENV | |
echo "LINKEDIN_CLIENT_ID=${{ secrets.LINKEDIN_CLIENT_ID }}" >> $GITHUB_ENV | |
echo "LINKEDIN_CLIENT_SECRET=${{ secrets.LINKEDIN_CLIENT_SECRET }}" >> $GITHUB_ENV | |
echo "TELEGRAM_TOKEN=${{ secrets.TELEGRAM_TOKEN }}" >> $GITHUB_ENV | |
echo "TELEGRAM_CHAT_ID=${{ secrets.TELEGRAM_CHAT_ID }}" >> $GITHUB_ENV | |
echo "CLOUDINARY_CLOUD_NAME=${{ secrets.CLOUDINARY_CLOUD_NAME }}" >> $GITHUB_ENV | |
echo "CLOUDINARY_API_KEY=${{ secrets.CLOUDINARY_API_KEY }}" >> $GITHUB_ENV | |
echo "CLOUDINARY_API_SECRET=${{ secrets.CLOUDINARY_API_SECRET }}" >> $GITHUB_ENV | |
echo "AZURE_AI_URL=${{ secrets.AZURE_AI_URL }}" >> $GITHUB_ENV | |
echo "AZURE_AI_API_KEY=${{ secrets.AZURE_AI_API_KEY }}" >> $GITHUB_ENV | |
- name: Run Treaty Tests | |
id: treaty_test | |
run: | | |
bun install | |
bunx prisma generate | |
bun test | |
echo "::set-output name=result::success" | |
- name: Mark as failed if tests fail | |
if: failure() | |
run: echo "::set-output name=result::failure" | |
build: | |
name: Build & Push to GHCR Registry | |
runs-on: self-hosted | |
needs: test | |
if: success() | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Settle up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Declaring some Global Environtment vars | |
run: | | |
echo "BRANCH_NAME=${GITHUB_REF##*/}" >> $GITHUB_ENV | |
echo "SHA=$(echo "$GITHUB_SHA" | head -c 7)" >> $GITHUB_ENV | |
echo "ENV=dev" >> $GITHUB_ENV | |
echo "PORT=3121" >> $GITHUB_ENV | |
echo "BASE_URL=https://api.xyzuan.my.id/dev" >> $GITHUB_ENV | |
echo "DOMAIN=xyzuan.my.id" >> $GITHUB_ENV | |
echo "REGISTRY=ghcr.io/xyzuan" >> $GITHUB_ENV | |
echo "IMAGE_NAME=xyzuan_api_v2" >> $GITHUB_ENV | |
echo "DOCKERFILE=misc/Dockerfile" >> $GITHUB_ENV | |
- name: Authenticating to Eden Server realms. | |
uses: webfactory/[email protected] | |
with: | |
ssh-private-key: ${{ secrets.SERVER_PRIVATE_KEY }} | |
- name: Authenticating to GHCR realms | |
run: echo "${{ secrets.GH_TOKEN }}" | docker login -u "${{ github.actor }}" ghcr.io --password-stdin | |
- name: Treaty Build the Docker image | |
run: | | |
docker build \ | |
--build-arg PORT=${{ env.PORT }} \ | |
--build-arg NODE_ENV=${{ env.ENV }} \ | |
--build-arg BASE_URL=${{ env.BASE_URL }} \ | |
--build-arg DOMAIN=${{ env.DOMAIN }} \ | |
--build-arg PASSWORD_PEPPER=${{ secrets.PASSWORD_PEPPER }} \ | |
--build-arg DATABASE_URL=${{ secrets.DATABASE_URL_DEV }} \ | |
--build-arg GOOGLE_CLIENT_ID=${{ secrets.GOOGLE_CLIENT_ID }} \ | |
--build-arg GOOGLE_CLIENT_SECRET=${{ secrets.GOOGLE_CLIENT_SECRET }} \ | |
--build-arg GITHUB_CLIENT_ID=${{ secrets.GH_CLIENT_ID }} \ | |
--build-arg GITHUB_CLIENT_SECRET=${{ secrets.GH_CLIENT_SECRET }} \ | |
--build-arg LINKEDIN_CLIENT_ID=${{ secrets.LINKEDIN_CLIENT_ID }} \ | |
--build-arg LINKEDIN_CLIENT_SECRET=${{ secrets.LINKEDIN_CLIENT_SECRET }} \ | |
--build-arg TELEGRAM_TOKEN=${{ secrets.TELEGRAM_TOKEN }} \ | |
--build-arg TELEGRAM_CHAT_ID=${{ secrets.TELEGRAM_CHAT_ID }} \ | |
--build-arg CLOUDINARY_CLOUD_NAME=${{ secrets.CLOUDINARY_CLOUD_NAME }} \ | |
--build-arg CLOUDINARY_API_KEY=${{ secrets.CLOUDINARY_API_KEY }} \ | |
--build-arg CLOUDINARY_API_SECRET=${{ secrets.CLOUDINARY_API_SECRET }} \ | |
--build-arg AZURE_AI_URL=${{ secrets.AZURE_AI_URL }} \ | |
--build-arg AZURE_AI_API_KEY=${{ secrets.AZURE_AI_API_KEY }} \ | |
-t ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.BRANCH_NAME }} -f ${{ env.DOCKERFILE }} . | |
- name: Adding tags to the Images | |
run: | | |
docker tag ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.BRANCH_NAME }} ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{env.SHA}} | |
- name: Bring the Images to GHCR | |
run: | | |
docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.BRANCH_NAME }} | |
docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{env.SHA}} | |
serve: | |
name: Serve Images in Server | |
runs-on: self-hosted | |
needs: build | |
if: success() | |
steps: | |
- name: Authenticating to Eden Server realms | |
uses: webfactory/[email protected] | |
with: | |
ssh-private-key: ${{ secrets.SERVER_PRIVATE_KEY }} | |
- name: Declaring some Global Environtment vars | |
run: | | |
echo "BRANCH_NAME=${GITHUB_REF##*/}" >> $GITHUB_ENV | |
echo "PORT=3121" >> $GITHUB_ENV | |
echo "CT_NAME=xyzuan-api-v2-dev" >> $GITHUB_ENV | |
echo "REGISTRY=ghcr.io/xyzuan" >> $GITHUB_ENV | |
echo "IMAGE_NAME=xyzuan_api_v2" >> $GITHUB_ENV | |
- name: Serve the Images | |
run: | | |
ssh-keyscan -t rsa ${{ secrets.SERVER_HOST }} >> ~/.ssh/known_hosts | |
ssh ${{ github.actor }}@${{ secrets.SERVER_HOST }} << 'EOF' | |
echo 'Authenticating to GHCR realms...' | |
echo "${{ secrets.GH_TOKEN }}" | docker login -u "${{ github.actor }}" ghcr.io --password-stdin | |
echo 'Pulling the latest image from GHCR...' | |
docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.BRANCH_NAME }} | |
echo 'Force Blowing the existing Docker Container...' | |
docker rm -f ${{ env.CT_NAME }} | |
echo 'Running the Docker Container...' | |
docker run -d \ | |
--name ${{ env.CT_NAME }} \ | |
--restart always \ | |
--network nginx_default \ | |
-p ${{ env.PORT }}:${{ env.PORT }} \ | |
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.BRANCH_NAME }} | |
EOF |