release
All checks were successful
Build Docker Images / build-and-push (push) Successful in 1m18s

This commit is contained in:
Michał Zieliński
2025-10-13 21:45:08 +02:00
parent 41c18590d8
commit bc3a76b82b

View File

@@ -1,12 +1,7 @@
name: Release Docker Images name: Release Docker Images
on: on:
workflow_dispatch: workflow_dispatch: {}
inputs:
build_id:
description: 'Build ID (leave empty for latest successful build)'
required: false
type: string
jobs: jobs:
release: release:
@@ -21,48 +16,36 @@ jobs:
with: with:
node-version: 20 node-version: 20
- name: Determine build ID
id: build
run: |
BUILD_ID="${{ github.event.inputs.build_id }}"
if [ -z "$BUILD_ID" ]; then
echo "No build_id provided, will use latest from packages"
# Fallback: you can implement logic to find latest build tag
echo "ERROR: Please provide build_id for now"
exit 1
fi
echo "build_id=$BUILD_ID" >> "$GITHUB_OUTPUT"
echo "Using build_id: $BUILD_ID"
- name: Log in to Gitea Container Registry - name: Log in to Gitea Container Registry
run: | run: |
echo "${{ secrets.REGISTRY_TOKEN }}" | docker login code.bim-it.pl -u "${{ secrets.REGISTRY_USER }}" --password-stdin echo "${{ secrets.REGISTRY_TOKEN }}" | docker login code.bim-it.pl -u "${{ secrets.REGISTRY_USER }}" --password-stdin
- name: Pull build artifacts (images) - name: Pull latest build artifacts (images)
run: | run: |
docker pull code.bim-it.pl/mz/bimai-api:build-${{ steps.build.outputs.build_id }} echo "Pulling latest build images..."
docker pull code.bim-it.pl/mz/bimai-ui:build-${{ steps.build.outputs.build_id }} docker pull code.bim-it.pl/mz/bimai-api:latest
docker pull code.bim-it.pl/mz/bimai-ui:latest
- name: Extract appsettings from images - name: Extract appsettings from images
run: | run: |
mkdir -p artifacts/api artifacts/ui mkdir -p artifacts/api artifacts/ui
# Extract from API image # Extract from API image
docker create --name temp-api code.bim-it.pl/mz/bimai-api:build-${{ steps.build.outputs.build_id }} docker create --name temp-api code.bim-it.pl/mz/bimai-api:latest
docker cp temp-api:/app/appsettings.Production.json artifacts/api/ docker cp temp-api:/app/appsettings.Production.json artifacts/api/
docker rm temp-api docker rm temp-api
# Extract from UI image # Extract from UI image
docker create --name temp-ui code.bim-it.pl/mz/bimai-ui:build-${{ steps.build.outputs.build_id }} docker create --name temp-ui code.bim-it.pl/mz/bimai-ui:latest
docker cp temp-ui:/app/appsettings.Production.json artifacts/ui/ docker cp temp-ui:/app/appsettings.Production.json artifacts/ui/
docker rm temp-ui docker rm temp-ui
- name: Show extracted configs (before tokenization) - name: Show extracted configs (before tokenization)
run: | run: |
echo "::group::API appsettings.Production.json" echo "::group::API appsettings.Production.json (with placeholders)"
cat artifacts/api/appsettings.Production.json cat artifacts/api/appsettings.Production.json
echo "::endgroup::" echo "::endgroup::"
echo "::group::UI appsettings.Production.json" echo "::group::UI appsettings.Production.json (with placeholders)"
cat artifacts/ui/appsettings.Production.json cat artifacts/ui/appsettings.Production.json
echo "::endgroup::" echo "::endgroup::"
@@ -70,14 +53,14 @@ jobs:
env: env:
SECRETS: ${{ toJson(secrets) }} SECRETS: ${{ toJson(secrets) }}
VARIABLES: ${{ toJson(vars) }} VARIABLES: ${{ toJson(vars) }}
RUN_ID: ${{ steps.build.outputs.build_id }} RUN_ID: ${{ github.run_id }}
run: | run: |
node .gitea/scripts/replaceTokens.js node .gitea/scripts/replaceTokens.js
- name: Show tokenized configs (after tokenization) - name: Show tokenized configs (after tokenization)
run: | run: |
echo "::group::API appsettings.Production.json (tokenized)" echo "::group::API appsettings.Production.json (tokenized, passwords hidden)"
cat artifacts/api/appsettings.Production.json | sed 's/Password=[^;]*/Password=***/g' cat artifacts/api/appsettings.Production.json | sed 's/Password=[^;]*/Password=***/g' | sed 's/"SecretKey":"[^"]*"/"SecretKey":"***"/g'
echo "::endgroup::" echo "::endgroup::"
echo "::group::UI appsettings.Production.json (tokenized)" echo "::group::UI appsettings.Production.json (tokenized)"
cat artifacts/ui/appsettings.Production.json cat artifacts/ui/appsettings.Production.json
@@ -87,45 +70,47 @@ jobs:
run: | run: |
# API # API
cat > Dockerfile.release.api <<'EOF' cat > Dockerfile.release.api <<'EOF'
FROM code.bim-it.pl/mz/bimai-api:build-${{ steps.build.outputs.build_id }} FROM code.bim-it.pl/mz/bimai-api:latest
LABEL org.opencontainers.image.source=https://code.bim-it.pl/mz/BimAI
COPY artifacts/api/appsettings.Production.json /app/ COPY artifacts/api/appsettings.Production.json /app/
EOF EOF
docker build -f Dockerfile.release.api \ docker build -f Dockerfile.release.api \
-t code.bim-it.pl/mz/bimai-api:prod \ -t code.bim-it.pl/mz/bimai-api:prod \
-t code.bim-it.pl/mz/bimai-api:release-${{ steps.build.outputs.build_id }} \ -t code.bim-it.pl/mz/bimai-api:release-${{ github.run_id }} \
. .
# UI # UI
cat > Dockerfile.release.ui <<'EOF' cat > Dockerfile.release.ui <<'EOF'
FROM code.bim-it.pl/mz/bimai-ui:build-${{ steps.build.outputs.build_id }} FROM code.bim-it.pl/mz/bimai-ui:latest
LABEL org.opencontainers.image.source=https://code.bim-it.pl/mz/BimAI
COPY artifacts/ui/appsettings.Production.json /app/ COPY artifacts/ui/appsettings.Production.json /app/
EOF EOF
docker build -f Dockerfile.release.ui \ docker build -f Dockerfile.release.ui \
-t code.bim-it.pl/mz/bimai-ui:prod \ -t code.bim-it.pl/mz/bimai-ui:prod \
-t code.bim-it.pl/mz/bimai-ui:release-${{ steps.build.outputs.build_id }} \ -t code.bim-it.pl/mz/bimai-ui:release-${{ github.run_id }} \
. .
- name: Push final images - name: Push final images
run: | run: |
docker push code.bim-it.pl/mz/bimai-api:prod docker push code.bim-it.pl/mz/bimai-api:prod
docker push code.bim-it.pl/mz/bimai-api:release-${{ steps.build.outputs.build_id }} docker push code.bim-it.pl/mz/bimai-api:release-${{ github.run_id }}
docker push code.bim-it.pl/mz/bimai-ui:prod docker push code.bim-it.pl/mz/bimai-ui:prod
docker push code.bim-it.pl/mz/bimai-ui:release-${{ steps.build.outputs.build_id }} docker push code.bim-it.pl/mz/bimai-ui:release-${{ github.run_id }}
- name: Output release info - name: Output release info
run: | run: |
echo "## Docker Images Released" >> $GITHUB_STEP_SUMMARY echo "## Docker Images Released" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY
echo "**Build ID:** ${{ steps.build.outputs.build_id }}" >> $GITHUB_STEP_SUMMARY
echo "**Release ID:** ${{ github.run_id }}" >> $GITHUB_STEP_SUMMARY echo "**Release ID:** ${{ github.run_id }}" >> $GITHUB_STEP_SUMMARY
echo "**Commit:** ${{ github.sha }}" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY
echo "### Pull commands:" >> $GITHUB_STEP_SUMMARY echo "### 🚀 Production images ready to deploy:" >> $GITHUB_STEP_SUMMARY
echo '```bash' >> $GITHUB_STEP_SUMMARY echo '```bash' >> $GITHUB_STEP_SUMMARY
echo "# Production (latest)" >> $GITHUB_STEP_SUMMARY echo "# Production (latest release)" >> $GITHUB_STEP_SUMMARY
echo "docker pull code.bim-it.pl/mz/bimai-api:prod" >> $GITHUB_STEP_SUMMARY echo "docker pull code.bim-it.pl/mz/bimai-api:prod" >> $GITHUB_STEP_SUMMARY
echo "docker pull code.bim-it.pl/mz/bimai-ui:prod" >> $GITHUB_STEP_SUMMARY echo "docker pull code.bim-it.pl/mz/bimai-ui:prod" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY
echo "# Specific release" >> $GITHUB_STEP_SUMMARY echo "# Specific release (for rollback)" >> $GITHUB_STEP_SUMMARY
echo "docker pull code.bim-it.pl/mz/bimai-api:release-${{ steps.build.outputs.build_id }}" >> $GITHUB_STEP_SUMMARY echo "docker pull code.bim-it.pl/mz/bimai-api:release-${{ github.run_id }}" >> $GITHUB_STEP_SUMMARY
echo "docker pull code.bim-it.pl/mz/bimai-ui:release-${{ steps.build.outputs.build_id }}" >> $GITHUB_STEP_SUMMARY echo "docker pull code.bim-it.pl/mz/bimai-ui:release-${{ github.run_id }}" >> $GITHUB_STEP_SUMMARY
echo '```' >> $GITHUB_STEP_SUMMARY echo '```' >> $GITHUB_STEP_SUMMARY