Skip to content

Commit c210038

Browse files
authored
Merge pull request #230 from huizebruin/jesserockz-2024-448
Use esphome build workflow
2 parents ca0847c + 52342af commit c210038

13 files changed

+49
-89
lines changed

.github/workflows/build.yml

+37-77
Original file line numberDiff line numberDiff line change
@@ -9,85 +9,29 @@ on:
99
release:
1010
types: [published]
1111

12-
env:
13-
RELEASE_URL: ${{ github.server_url }}/${{ github.repository }}/releases/latest
14-
FIRMWARES: |
15-
s0tool
16-
1712
jobs:
1813
build:
19-
name: Build ${{ matrix.firmware.name }}
20-
runs-on: ubuntu-latest
21-
strategy:
22-
matrix:
23-
firmware:
24-
- file: esphome/watermeter.yaml
25-
name: s0tool-watermeter
26-
manifest_filename: s0tool-watermeter-manifest.json
27-
- file: esphome/pulscounter.yaml
28-
name: s0tool-standard
29-
manifest_filename: s0tool-standard-manifest.json
30-
- file: esphome/S0-puls-kwhpuls.yaml
31-
name: s0tool-kwh-puls
32-
manifest_filename: s0tool-kwh-puls-manifest.json
33-
- file: esphome/S0-puls-DSZ12D.yaml
34-
name: s0tool-dsz12d
35-
manifest_filename: s0tool-dsz12d-manifest.json
36-
- file: esphome/S0-puls-LEM022SJ.yaml
37-
name: s0tool-lem022sj
38-
manifest_filename: s0tool-lem022sj-manifest.json
39-
- file: esphome/s0-watermeter.yaml
40-
name: s0tool-s0-watermeter
41-
manifest_filename: s0tool-s0-watermeter-manifest.json
42-
- file: esphome/wsz15d32a.yaml
43-
name: s0tool-wsz15d32a
44-
manifest_filename: s0tool-wsz15d32a-manifest.json
45-
- file: esphome/sdm72d.yaml
46-
name: s0tool-sdm72d
47-
manifest_filename: s0tool-sdm72d-manifest.json
48-
- file: esphome/puls-water-internal.yaml
49-
name: s0tool-standard-internal
50-
manifest_filename: s0tool-standard-internal-manifest.json
51-
- file: esphome/kwh-water-test.yaml
52-
name: s0tool-kwh-water-test
53-
manifest_filename: s0tool-kwh-water-test-manifest.json
54-
- file: esphome/pulscounter_flux.yaml
55-
name: s0tool-standard-flux
56-
manifest_filename: s0tool-standard-flux-manifest.json
57-
58-
fail-fast: false
59-
steps:
60-
- name: Checkout source code
61-
uses: actions/checkout@v4
62-
63-
- name: Read version from YAML file
64-
id: read_version
65-
run: |
66-
project_version=$(grep 'project_version:' esphome/components/basis.yaml | awk '{print $2}' | tr -d '"')
67-
echo "project_version=$project_version" >> $GITHUB_ENV
68-
69-
- name: Build firmware
70-
uses: esphome/build-action@v3.2.0
71-
id: esphome-build
72-
with:
73-
yaml_file: ${{ matrix.firmware.file }}
74-
version: 2024.7.3
75-
release_url: ${{ github.event.release.html_url || env.RELEASE_URL }}
76-
77-
- name: Copy firmware and manifest 🔨
78-
run: |
79-
mkdir output
80-
mv ${{ steps.esphome-build.outputs.name }} output/
81-
jq -s "{\"name\": \"${{ matrix.firmware.name }}\", \"version\": \"${{ env.project_version }}\", \"home_assistant_domain\": \"esphome\", \"new_install_prompt_erase\": false, \"builds\":.}" output/${{ steps.esphome-build.outputs.name }}/manifest.json > output/${{ matrix.firmware.manifest_filename }}
82-
83-
- name: Upload artifact
84-
uses: actions/upload-artifact@v4.4.0
85-
with:
86-
name: ${{ matrix.firmware.name }}
87-
path: output
14+
name: Build firmware 🛠️
15+
uses: esphome/workflows/.github/workflows/build.yml@main
16+
with:
17+
files: |
18+
esphome/watermeter.yaml
19+
esphome/pulscounter.yaml
20+
esphome/S0-puls-kwhpuls.yaml
21+
esphome/S0-puls-DSZ12D.yaml
22+
esphome/S0-puls-LEM022SJ.yaml
23+
esphome/s0-watermeter.yaml
24+
esphome/wsz15d32a.yaml
25+
esphome/sdm72d.yaml
26+
esphome/puls-water-internal.yaml
27+
esphome/kwh-water-test.yaml
28+
esphome/pulscounter_flux.yaml
29+
esphome-version: 2024.7.3
30+
release-summary: ${{ github.event_name == 'release' && github.event.release.body || '' }}
31+
release-url: ${{ github.event_name == 'release' && github.event.release.html_url || '' }}
32+
release-version: ${{ github.event_name == 'release' && github.event.release.tag_name || '' }}
8833

8934
consolidate:
90-
if: github.event_name != 'pull_request' && github.ref == 'refs/heads/main'
9135
name: Consolidate firmwares 🚀
9236
runs-on: ubuntu-latest
9337
needs: build
@@ -98,18 +42,34 @@ jobs:
9842
uses: actions/download-artifact@v4
9943
with:
10044
path: firmwares
45+
- name: Remove intermediate version folder
46+
run: |-
47+
for d in firmwares/*/*; do
48+
if [ -d "$d" ]; then
49+
mv $d/* $d/../
50+
rm -rf $d
51+
fi
52+
done
10153
- name: Copy files
10254
run: |-
10355
mkdir output
10456
cp -R static/* output/
105-
cp -R firmwares/*/* output/
57+
cp -R firmwares/* output/
58+
- name: Copy manifest files to root and modify paths # This is required so that older firmwares can update to newer firmwares with new manifest paths
59+
run: |-
60+
for device in firmwares/*; do
61+
device=$(basename $device)
62+
jq --arg device "$device" \
63+
'.builds[].ota.path |= $device + "/" + . | (.builds[].parts // [])[].path |= $device + "/" + .' \
64+
firmwares/$device/manifest.json > output/$device-manifest.json
65+
done
10666
- name: Upload GitHub Pages artifact
10767
uses: actions/upload-pages-artifact@v3.0.1
10868
with:
10969
path: output
11070

11171
deploy:
112-
if: github.event_name != 'pull_request' && github.ref == 'refs/heads/main'
72+
if: github.event_name == 'release'
11373
name: Deploy to GitHub Pages 🚀
11474
runs-on: ubuntu-latest
11575
needs: consolidate

esphome/components/s0tool-dsz12d-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -3,4 +3,4 @@ update:
33
- platform: http_request
44
name: Firmware Update
55
id: update_http_request
6-
source: https://s0tool.nl/s0tool-dsz12d-manifest.json
6+
source: https://s0tool.nl/s0tool-dsz12d/manifest.json

esphome/components/s0tool-kwh-puls-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-kwh-puls-manifest.json
5+
source: https://s0tool.nl/s0tool-kwh-puls/manifest.json

esphome/components/s0tool-kwh-water-test-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-kwh-water-test-manifest.json
5+
source: https://s0tool.nl/s0tool-kwh-water-test/manifest.json

esphome/components/s0tool-lem022sj-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-lem022sj-manifest.json
5+
source: https://s0tool.nl/s0tool-lem022sj/manifest.json

esphome/components/s0tool-s0-watermeter-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-s0-watermeter-manifest.json
5+
source: https://s0tool.nl/s0tool-s0-watermeter/manifest.json

esphome/components/s0tool-sdm72d-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-sdm72d-manifest.json
5+
source: https://s0tool.nl/s0tool-sdm72d/manifest.json

esphome/components/s0tool-standard-flux-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-standard-flux-manifest.json
5+
source: https://s0tool.nl/s0tool-standard-flux/manifest.json

esphome/components/s0tool-standard-internal-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-standard-internal-manifest.json
5+
source: https://s0tool.nl/s0tool-standard-internal/manifest.json

esphome/components/s0tool-standard-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-standard-manifest.json
5+
source: https://s0tool.nl/s0tool-standard/manifest.json

esphome/components/s0tool-watermeter-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-watermeter-manifest.json
5+
source: https://s0tool.nl/s0tool-watermeter/manifest.json

esphome/components/s0tool-wsz15d32a-update.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,4 @@ update:
22
- platform: http_request
33
name: Firmware Update
44
id: update_http_request
5-
source: https://s0tool.nl/s0tool-wsz15d32a-manifest.json
5+
source: https://s0tool.nl/s0tool-wsz15d32a/manifest.json

static/Installation.html

+1-1
Original file line numberDiff line numberDiff line change
@@ -256,7 +256,7 @@ <h3>s0tool-standard-flux</h3>
256256
document.querySelectorAll('input[name="type"]').forEach((radio) =>
257257
radio.addEventListener("change", () => {
258258
const button = document.querySelector("esp-web-install-button");
259-
button.manifest = `./${radio.value}-manifest.json`;
259+
button.manifest = `./${radio.value}/manifest.json`;
260260

261261
document.querySelectorAll(".info").forEach((info) => {
262262
info.classList.add("hidden");

0 commit comments

Comments
 (0)