From 32f202d814595340ac362afd6c18149c19adffe8 Mon Sep 17 00:00:00 2001 From: kris Date: Sun, 9 Nov 2025 09:23:32 +0000 Subject: [PATCH] Update .gitlab-ci.yml file --- .gitlab-ci.yml | 33 +++++++++++++++++++++++++++------ 1 file changed, 27 insertions(+), 6 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 603dc72d..4291765e 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -3,12 +3,25 @@ stages: - deploy variables: + # ๐Ÿ”ง Docker BuildKit lebih cepat DOCKER_BUILDKIT: "1" COMPOSE_DOCKER_CLI_BUILD: "1" DOCKER_DRIVER: overlay2 + + # ๐Ÿง  Tag image berdasarkan commit IMAGE_NAME: "$CI_REGISTRY_IMAGE/web-lti:development_${CI_COMMIT_SHORT_SHA}" + + # ๐Ÿ“ฆ Cache npm antar pipeline NPM_CACHE_DIR: "$CI_PROJECT_DIR/.npm" + # ๐ŸŒ Environment default untuk Next.js + NODE_ENV: "production" + HUSKY_SKIP_INSTALL: "1" + + # โš™๏ธ Inject ENV dari GitLab CI Variables ke Dockerfile + NEXT_PUBLIC_API_BASE_URL: "${NEXT_PUBLIC_API_BASE_URL}" + NEXT_PUBLIC_LTI_API_START_URL: "${NEXT_PUBLIC_LTI_API_START_URL}" + cache: key: npm-cache paths: @@ -24,14 +37,22 @@ build-image: - docker:dind before_script: - - echo "Logging in to GitLab Container Registry..." + - echo "๐Ÿ” Logging in to GitLab Container Registry..." - echo "$CI_REGISTRY_PASSWORD" | docker login -u "$CI_REGISTRY_USER" --password-stdin "$CI_REGISTRY" script: - - echo "Building optimized Docker image..." - - docker build --build-arg BUILDKIT_INLINE_CACHE=1 --cache-from "$CI_REGISTRY_IMAGE/web-lti:latest" -t "$IMAGE_NAME" . + - echo "๐Ÿšง Building optimized Docker image..." + - > + docker build + --build-arg NEXT_PUBLIC_API_BASE_URL="$NEXT_PUBLIC_API_BASE_URL" + --build-arg NEXT_PUBLIC_LTI_API_START_URL="$NEXT_PUBLIC_LTI_API_START_URL" + --build-arg NODE_ENV="$NODE_ENV" + --build-arg HUSKY_SKIP_INSTALL="$HUSKY_SKIP_INSTALL" + --build-arg BUILDKIT_INLINE_CACHE=1 + --cache-from "$CI_REGISTRY_IMAGE/web-lti:latest" + -t "$IMAGE_NAME" . - docker push "$IMAGE_NAME" - - echo "Cleaning old images..." + - echo "๐Ÿงน Cleaning old images..." - docker image prune -af --filter "until=72h" rules: @@ -45,7 +66,7 @@ deploy-dev: image: alpine:3.20 before_script: - - echo "Installing dependencies..." + - echo "๐Ÿ“ฆ Installing dependencies..." - apk add --no-cache openssh curl - mkdir -p ~/.ssh - echo "$SSH_PRIVATE_KEY" > ~/.ssh/id_rsa @@ -55,7 +76,7 @@ deploy-dev: - ssh-keyscan -H "$SERVER_IP" >> ~/.ssh/known_hosts script: - - echo "Deploying image to $SERVER_USER@$SERVER_IP" + - echo "๐Ÿš€ Deploying image to $SERVER_USER@$SERVER_IP" - > ssh -o StrictHostKeyChecking=no "$SERVER_USER@$SERVER_IP" " docker pull $CI_REGISTRY_IMAGE/web-lti:development_${CI_COMMIT_SHORT_SHA} &&