Publish Release #25
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 Release | |
on: | |
workflow_dispatch: | |
release: | |
types: [published] | |
schedule: | |
- cron: "0 2 * * *" | |
permissions: | |
contents: read | |
jobs: | |
init: | |
name: Initialize build | |
runs-on: ubuntu-latest | |
outputs: | |
tag: ${{ steps.tag.outputs.tag }} | |
steps: | |
- uses: actions/checkout@v4.1.1 | |
- name: Get tag | |
id: tag | |
# yamllint disable rule:line-length | |
run: | | |
if [[ "$GITHUB_EVENT_NAME" = "release" ]]; then | |
TAG="${GITHUB_REF#refs/tags/}" | |
else | |
TAG=$(cat esphome/const.py | sed -n -E "s/^__version__\s+=\s+\"(.+)\"$/\1/p") | |
today="$(date --utc '+%Y%m%d')" | |
TAG="${TAG}${today}" | |
BRANCH=${GITHUB_REF#refs/heads/} | |
if [[ "$BRANCH" != "dev" ]]; then | |
TAG="${TAG}-${BRANCH}" | |
fi | |
fi | |
echo "tag=${TAG}" >> $GITHUB_OUTPUT | |
# yamllint enable rule:line-length | |
deploy-pypi: | |
name: Build and publish to PyPi | |
if: github.repository == 'esphome/esphome' && github.event_name == 'release' | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4.1.1 | |
- name: Set up Python | |
uses: actions/setup-python@v5.1.0 | |
with: | |
python-version: "3.x" | |
- name: Set up python environment | |
env: | |
ESPHOME_NO_VENV: 1 | |
run: | | |
script/setup | |
pip install twine | |
- name: Build | |
run: python setup.py sdist bdist_wheel | |
- name: Upload | |
env: | |
TWINE_USERNAME: __token__ | |
TWINE_PASSWORD: ${{ secrets.PYPI_TOKEN }} | |
run: twine upload dist/* | |
deploy-docker: | |
name: Build ESPHome ${{ matrix.platform }} | |
if: github.repository == 'esphome/esphome' | |
permissions: | |
contents: read | |
packages: write | |
runs-on: ubuntu-latest | |
needs: [init] | |
strategy: | |
fail-fast: false | |
matrix: | |
platform: | |
- linux/amd64 | |
- linux/arm/v7 | |
- linux/arm64 | |
steps: | |
- uses: actions/checkout@v4.1.1 | |
- name: Set up Python | |
uses: actions/setup-python@v5.1.0 | |
with: | |
python-version: "3.9" | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3.3.0 | |
- name: Set up QEMU | |
if: matrix.platform != 'linux/amd64' | |
uses: docker/setup-qemu-action@v3.0.0 | |
- name: Log in to docker hub | |
uses: docker/login-action@v3.1.0 | |
with: | |
username: ${{ secrets.DOCKER_USER }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Log in to the GitHub container registry | |
uses: docker/login-action@v3.1.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build docker | |
uses: ./.github/actions/build-image | |
with: | |
platform: ${{ matrix.platform }} | |
target: docker | |
baseimg: docker | |
suffix: "" | |
version: ${{ needs.init.outputs.tag }} | |
- name: Build ha-addon | |
uses: ./.github/actions/build-image | |
with: | |
platform: ${{ matrix.platform }} | |
target: hassio | |
baseimg: hassio | |
suffix: "hassio" | |
version: ${{ needs.init.outputs.tag }} | |
- name: Build lint | |
uses: ./.github/actions/build-image | |
with: | |
platform: ${{ matrix.platform }} | |
target: lint | |
baseimg: docker | |
suffix: lint | |
version: ${{ needs.init.outputs.tag }} | |
deploy-manifest: | |
name: Publish ESPHome ${{ matrix.image.title }} to ${{ matrix.registry }} | |
runs-on: ubuntu-latest | |
needs: | |
- init | |
- deploy-docker | |
if: github.repository == 'esphome/esphome' | |
permissions: | |
contents: read | |
packages: write | |
strategy: | |
fail-fast: false | |
matrix: | |
image: | |
- title: "ha-addon" | |
target: "hassio" | |
suffix: "hassio" | |
- title: "docker" | |
target: "docker" | |
suffix: "" | |
- title: "lint" | |
target: "lint" | |
suffix: "lint" | |
registry: | |
- ghcr | |
- dockerhub | |
steps: | |
- uses: actions/checkout@v4.1.1 | |
- name: Download digests | |
uses: actions/download-artifact@v3.0.2 | |
with: | |
name: digests-${{ matrix.image.target }}-${{ matrix.registry }} | |
path: /tmp/digests | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3.3.0 | |
- name: Log in to docker hub | |
if: matrix.registry == 'dockerhub' | |
uses: docker/login-action@v3.1.0 | |
with: | |
username: ${{ secrets.DOCKER_USER }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Log in to the GitHub container registry | |
if: matrix.registry == 'ghcr' | |
uses: docker/login-action@v3.1.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Generate short tags | |
id: tags | |
run: | | |
output=$(docker/generate_tags.py \ | |
--tag "${{ needs.init.outputs.tag }}" \ | |
--suffix "${{ matrix.image.suffix }}" \ | |
--registry "${{ matrix.registry }}") | |
echo $output | |
for l in $output; do | |
echo $l >> $GITHUB_OUTPUT | |
done | |
- name: Create manifest list and push | |
working-directory: /tmp/digests | |
run: | | |
docker buildx imagetools create $(jq -Rcnr 'inputs | . / "," | map("-t " + .) | join(" ")' <<< "${{ steps.tags.outputs.tags}}") \ | |
$(printf '${{ steps.tags.outputs.image }}@sha256:%s ' *) | |
deploy-ha-addon-repo: | |
if: github.repository == 'esphome/esphome' && github.event_name == 'release' | |
runs-on: ubuntu-latest | |
needs: [deploy-manifest] | |
steps: | |
- name: Trigger Workflow | |
uses: actions/github-script@v7.0.1 | |
with: | |
github-token: ${{ secrets.DEPLOY_HA_ADDON_REPO_TOKEN }} | |
script: | | |
github.rest.actions.createWorkflowDispatch({ | |
owner: "esphome", | |
repo: "home-assistant-addon", | |
workflow_id: "bump-version.yml", | |
ref: "main", | |
inputs: { | |
version: "${{ github.event.release.tag_name }}", | |
content: ${{ toJSON(github.event.release.body) }} | |
} | |
}) |