Publish images to Docker Hub #168
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: Publish images to Docker Hub | |
on: | |
push: | |
# Will run for every tag pushed except `latest` | |
# When the `latest` git tag is created with this [CI](../latest-git-tag.yml) | |
# we don't need to create a Docker `latest` image again. | |
# The `latest` Docker image push is already done in this CI when releasing a stable version of Meilisearch. | |
tags-ignore: | |
- latest | |
# Both `schedule` and `workflow_dispatch` build the nightly tag | |
schedule: | |
- cron: '0 23 * * *' # Every day at 11:00pm | |
workflow_dispatch: | |
jobs: | |
docker: | |
runs-on: docker | |
steps: | |
- uses: actions/checkout@v3 | |
# If we are running a cron or manual job ('schedule' or 'workflow_dispatch' event), it means we are publishing the `nightly` tag, so not considered stable. | |
# If we have pushed a tag, and the tag has the v<nmumber>.<number>.<number> format, it means we are publishing an official release, so considered stable. | |
# In this situation, we need to set `output.stable` to create/update the following tags (additionally to the `vX.Y.Z` Docker tag): | |
# - a `vX.Y` (without patch version) Docker tag | |
# - a `latest` Docker tag | |
# For any other tag pushed, this is not considered stable. | |
- name: Define if stable and latest release | |
id: check-tag-format | |
env: | |
# To avoid request limit with the .github/scripts/is-latest-release.sh script | |
GITHUB_PATH: ${{ secrets.MEILI_BOT_GH_PAT }} | |
run: | | |
escaped_tag=$(printf "%q" ${{ github.ref_name }}) | |
echo "latest=false" >> $GITHUB_OUTPUT | |
if [[ ${{ github.event_name }} != 'push' ]]; then | |
echo "stable=false" >> $GITHUB_OUTPUT | |
elif [[ $escaped_tag =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then | |
echo "stable=true" >> $GITHUB_OUTPUT | |
echo "latest=$(sh .github/scripts/is-latest-release.sh)" >> $GITHUB_OUTPUT | |
else | |
echo "stable=false" >> $GITHUB_OUTPUT | |
fi | |
# Check only the validity of the tag for stable releases (not for pre-releases or other tags) | |
- name: Check release validity | |
if: steps.check-tag-format.outputs.stable == 'true' | |
run: bash .github/scripts/check-release.sh | |
- name: Set build-args for Docker buildx | |
id: build-metadata | |
run: | | |
# Extract commit date | |
commit_date=$(git show -s --format=%cd --date=iso-strict ${{ github.sha }}) | |
echo "date=$commit_date" >> $GITHUB_OUTPUT | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@v5 | |
with: | |
images: getmeili/meilisearch | |
# Prevent `latest` to be updated for each new tag pushed. | |
# We need latest and `vX.Y` tags to only be pushed for the stable Meilisearch releases. | |
flavor: latest=false | |
tags: | | |
type=ref,event=tag | |
type=raw,value=nightly,enable=${{ github.event_name != 'push' }} | |
type=semver,pattern=v{{major}}.{{minor}},enable=${{ steps.check-tag-format.outputs.stable == 'true' }} | |
type=raw,value=latest,enable=${{ steps.check-tag-format.outputs.stable == 'true' && steps.check-tag-format.outputs.latest == 'true' }} | |
- name: Build and push | |
uses: docker/build-push-action@v5 | |
with: | |
push: true | |
platforms: linux/amd64,linux/arm64 | |
tags: ${{ steps.meta.outputs.tags }} | |
build-args: | | |
COMMIT_SHA=${{ github.sha }} | |
COMMIT_DATE=${{ steps.build-metadata.outputs.date }} | |
GIT_TAG=${{ github.ref_name }} | |
# /!\ Don't touch this without checking with Cloud team | |
- name: Send CI information to Cloud team | |
# Do not send if nightly build (i.e. 'schedule' or 'workflow_dispatch' event) | |
if: github.event_name == 'push' | |
uses: peter-evans/repository-dispatch@v2 | |
with: | |
token: ${{ secrets.MEILI_BOT_GH_PAT }} | |
repository: meilisearch/meilisearch-cloud | |
event-type: cloud-docker-build | |
client-payload: '{ "meilisearch_version": "${{ github.ref_name }}", "stable": "${{ steps.check-tag-format.outputs.stable }}" }' |