Skip to content

Docker Build Workflow #2

Docker Build Workflow

Docker Build Workflow #2

Workflow file for this run

# .github/workflows/docker-build.yml
name: Docker Build Workflow
# Define the triggers for this workflow
on:
push:
branches:
- main
workflow_dispatch: # enables manual runs
jobs:
validate:
name: Validate Environment
runs-on: ubuntu-latest
services:
docker:
image: docker:20.10.16
options: --privileged
env:
DOCKER_TLS_CERTDIR: "/certs"
CI_REGISTRY_PATH: index.docker.io/ahoylabs
CI_REGISTRY_USER: ${{ secrets.CI_REGISTRY_USER }}
CI_REGISTRY_PASSWORD: ${{ secrets.CI_REGISTRY_PASSWORD }}
steps:
- name: Set up Docker
run: |
docker info
docker login -u "${{ secrets.CI_REGISTRY_USER }}" -p "${{ secrets.CI_REGISTRY_PASSWORD }}" ${{ env.CI_REGISTRY_PATH }}
- name: Print Environment Variables
run: |
echo "GitHub Actions env"
printenv
echo "CI_REGISTRY_USER ${{ secrets.CI_REGISTRY_USER }}"
echo "CI_REGISTRY_PASSWORD ${{ secrets.CI_REGISTRY_PASSWORD }}"
echo "CI_REGISTRY_PATH ${{ env.CI_REGISTRY_PATH }}"
build:
name: Build styletts2-api Image
runs-on: ubuntu-latest
needs: validate
services:
docker:
image: docker:20.10.16
options: --privileged
env:
IMAGE: styletts2-api
CI_REGISTRY_PATH: index.docker.io/ahoylabs
CI_REGISTRY_USER: ${{ secrets.CI_REGISTRY_USER }}
CI_REGISTRY_PASSWORD: ${{ secrets.CI_REGISTRY_PASSWORD }}
steps:
- name: Check out repository
uses: actions/checkout@v3
- name: Log in to Docker Hub
run: docker login -u "${{ secrets.CI_REGISTRY_USER }}" -p "${{ secrets.CI_REGISTRY_PASSWORD }}"
- name: Build styletts2-api Docker image
run: |
docker build --pull -t "${{ env.CI_REGISTRY_PATH }}/${{ env.IMAGE }}" .
docker push "${{ env.CI_REGISTRY_PATH }}/${{ env.IMAGE }}"