Skip to content

fix: update Docker secrets names #4

fix: update Docker secrets names

fix: update Docker secrets names #4

name: Build and Push Docker Image
on:
push:
branches:
- main
workflow_dispatch:
env:
REGISTRY: docker.io
IMAGE_NAME: paulorhramos/hello-argocd
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Generate image tag
id: tag
run: |
SHORT_SHA=$(echo ${{ github.sha }} | cut -c1-7)
echo "tag=${SHORT_SHA}" >> $GITHUB_OUTPUT
echo "date=$(date +'%Y%m%d-%H%M%S')" >> $GITHUB_OUTPUT
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: |
${{ env.IMAGE_NAME }}:${{ steps.tag.outputs.tag }}
${{ env.IMAGE_NAME }}:latest
cache-from: type=registry,ref=${{ env.IMAGE_NAME }}:buildcache
cache-to: type=registry,ref=${{ env.IMAGE_NAME }}:buildcache,mode=max
- name: Update Kubernetes manifest
run: |
sed -i "s|image: ${IMAGE_NAME}:.*|image: ${IMAGE_NAME}:${{ steps.tag.outputs.tag }}|g" k8s/deployment.yaml
cat k8s/deployment.yaml
env:
IMAGE_NAME: ${{ env.IMAGE_NAME }}
- name: Commit and push manifest changes
run: |
git config user.name "GitHub Actions"
git config user.email "[email protected]"
git add k8s/deployment.yaml
git commit -m "chore: update image to ${{ steps.tag.outputs.tag }}" || echo "No changes to commit"
git push