diff --git a/.github/workflows/beta.yml b/.github/workflows/beta.yml
new file mode 100644
index 0000000..63c3496
--- /dev/null
+++ b/.github/workflows/beta.yml
@@ -0,0 +1,121 @@
+name: NukiHub Beta
+on:
+ workflow_dispatch:
+
+permissions:
+ contents: write
+
+jobs:
+ build:
+ name: Build ${{ matrix.board }} (${{ matrix.build }})
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ board: [esp32dev, esp32-s3, esp32-c3, esp32-c6, esp32solo1]
+ build: [release]
+ env:
+ BOARD: ${{ matrix.board }}
+ VARIANT: ${{ matrix.name || matrix.board }}
+ BUILD: ${{ matrix.build }}
+ steps:
+ - name: Fix variant name
+ run: |
+ # remove dash character
+ export VARIANT=${VARIANT//-/}
+
+ if [ "$VARIANT" = "esp32dev" ]; then
+ VARIANT="esp32"
+ fi
+
+ echo "VARIANT=${VARIANT}" | tee -a ${GITHUB_ENV}
+ - uses: actions/checkout@v4
+ with:
+ submodules: recursive
+ - uses: actions/cache@v4
+ with:
+ path: |
+ ~/.cache/pip
+ ~/.platformio/.cache
+ ~/.platformio/packages
+ key: ${{ runner.os }}-pio-${{ matrix.board }}
+ - uses: actions/setup-python@v5
+ with:
+ python-version: '3.9'
+ - name: Install dependencies
+ run: make deps
+ - name: Add version info
+ env:
+ Version: ${{ github.run_id }}.${{ github.run_number }}.${{ github.run_attempt }}
+ run: |
+ sed -i "s/unknownbuildnr/$Version (${BUILD})/g" src/Config.h
+ - name: Build ${{ matrix.build }} PlatformIO Project ${{ matrix.board }}
+ run: |
+ if [ "$BUILD" = "debug" ]; then
+ BOARD="${BOARD}_dbg"
+ fi
+ echo "::group::Building with PlatformIO"
+ if [ "$BUILD" = "release" ]; then
+ make updater_${BOARD}
+ fi
+ make $BOARD
+ echo "::endgroup::"
+ - name: Add flash script
+ env:
+ DOC: resources/how-to-flash.txt
+ FILES: ${{ format('{0}/{1}', env.BUILD, env.VARIANT) }}
+ run: |
+ BOARD=`echo $BOARD | tr '[:lower:]' '[:upper:]'`
+
+ # fix for docs
+ if [ "$BOARD" = "ESP32DEV" ]; then
+ BOARD="ESP32"
+ fi
+
+ # look for documentation on flash and copy the command
+ command=`sed -n '/^Howto flash (esptool)$/,$p' ${DOC} | sed -n '/^## '"${BOARD}"'$/,\${ n; n; p; }' | head -n1`
+
+ if [ -z "$command" ]; then
+ echo "::error::Command not found in document ${DOC} for board ${BOARD}"
+ exit 1
+ fi
+
+ echo -n "Command: "
+ echo "$command" | tee ${FILES}/flash.sh
+ chmod a+x ${FILES}/flash.sh
+
+ - name: Upload Artifact ${{ matrix.board }}-${{ matrix.build }}
+ uses: actions/upload-artifact@v4
+ with:
+ name: ${{ format('{0}-{1}-assets', env.VARIANT, matrix.build) }}
+ path: ${{ matrix.build }}/${{ env.VARIANT }}
+ ota-beta:
+ name: Create beta from latest master
+ needs: build
+ runs-on: ubuntu-latest
+ steps:
+ - name: Git Checkout
+ uses: actions/checkout@v4
+ with:
+ ref: ${{ github.head_ref }}
+ - name: Download release assets
+ uses: actions/download-artifact@v4
+ with:
+ path: release
+ pattern: '*-release-assets'
+ - name: Copy binaries to ota/beta
+ run: |
+ mkdir -p ota/beta/
+ cp -vf release/*/nuki_hub_*.bin ota/beta/
+ rm -rf release
+ - name: Commit binaries to master
+ uses: stefanzweifel/git-auto-commit-action@v5
+ with:
+ commit_message: "Update beta binaries"
+ file_pattern: 'ota/beta/*.bin'
+ branch: master
+ skip_dirty_check: true
+ skip_fetch: true
+ skip_checkout: true
+ disable_globbing: true
+ add_options: '-f'
\ No newline at end of file
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
index dfc22b6..bbb0080 100644
--- a/.github/workflows/build.yml
+++ b/.github/workflows/build.yml
@@ -6,7 +6,6 @@ on:
pull_request:
branches: ["*"]
tags: ["*"]
-
workflow_dispatch:
permissions:
@@ -96,7 +95,6 @@ jobs:
with:
name: ${{ format('{0}-{1}-assets', env.VARIANT, matrix.build) }}
path: ${{ matrix.build }}/${{ env.VARIANT }}
-
release:
name: Release new version
needs: build
@@ -109,7 +107,7 @@ jobs:
- name: Git Checkout
uses: actions/checkout@v4
with:
- ref: ${{ github.head_ref }}
+ ref: ${{ github.head_ref }}
- name: Download release assets
uses: actions/download-artifact@v4
with:
@@ -168,16 +166,22 @@ jobs:
name: "Nuki Hub ${{ steps.get_version.outputs.VERSION }}"
artifacts: ${{ steps.zip.outputs.artifacts }}
artifactContentType: application/zip
- - name: Copy binaries to ota and webflash
+ - name: Copy binaries to ota and webflash and remove beta
run: |
cp -vf release/*/nuki_hub_*.bin ota/
cp -vf release/*/webflash_nuki_hub_*.bin webflash/
rm -rf release
rm -rf debug
rm -rf NukiHub-*.zip
+ git rm -r --cached ota/beta/*.bin
- name: Commit binaries to master
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: "Update binaries for version ${{ steps.get_version.outputs.VERSION }}"
- file_pattern: 'ota/*.bin webflash/*.bin'
+ file_pattern: 'ota/*.bin ota/beta/*.bin ota/beta/debug/*.bin webflash/*.bin'
branch: master
+ skip_dirty_check: true
+ skip_fetch: true
+ skip_checkout: true
+ disable_globbing: true
+ add_options: '-f'
\ No newline at end of file
diff --git a/.github/workflows/nightly.yml b/.github/workflows/nightly.yml
new file mode 100644
index 0000000..f619887
--- /dev/null
+++ b/.github/workflows/nightly.yml
@@ -0,0 +1,127 @@
+name: NukiHub Nightly
+on:
+ workflow_dispatch:
+ schedule:
+ - cron: "30 0 * * *"
+
+permissions:
+ contents: write
+
+jobs:
+ build:
+ name: Build ${{ matrix.board }} (${{ matrix.build }})
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ board: [esp32dev, esp32-s3, esp32-c3, esp32-c6, esp32solo1]
+ build: [release]
+ env:
+ BOARD: ${{ matrix.board }}
+ VARIANT: ${{ matrix.name || matrix.board }}
+ BUILD: ${{ matrix.build }}
+ steps:
+ - name: Fix variant name
+ run: |
+ # remove dash character
+ export VARIANT=${VARIANT//-/}
+
+ if [ "$VARIANT" = "esp32dev" ]; then
+ VARIANT="esp32"
+ fi
+
+ echo "VARIANT=${VARIANT}" | tee -a ${GITHUB_ENV}
+ - uses: actions/checkout@v4
+ with:
+ fetch-depth: 0
+ submodules: recursive
+ - name: Get new commits
+ run: echo "NEW_COMMIT_COUNT=$(git log --oneline --since '24 hours ago' | wc -l)" >> $GITHUB_ENV
+ - uses: actions/cache@v4
+ if: ${{ env.NEW_COMMIT_COUNT > 1 }}
+ with:
+ path: |
+ ~/.cache/pip
+ ~/.platformio/.cache
+ ~/.platformio/packages
+ key: ${{ runner.os }}-pio-${{ matrix.board }}
+ - uses: actions/setup-python@v5
+ with:
+ python-version: '3.9'
+ - name: Install dependencies
+ run: make deps
+ - name: Add version info
+ env:
+ Version: ${{ github.run_id }}.${{ github.run_number }}.${{ github.run_attempt }}
+ run: |
+ sed -i "s/unknownbuildnr/$Version (${BUILD})/g" src/Config.h
+ - name: Build ${{ matrix.build }} PlatformIO Project ${{ matrix.board }}
+ run: |
+ if [ "$BUILD" = "debug" ]; then
+ BOARD="${BOARD}_dbg"
+ fi
+ echo "::group::Building with PlatformIO"
+ if [ "$BUILD" = "release" ]; then
+ make updater_${BOARD}
+ fi
+ make $BOARD
+ echo "::endgroup::"
+ - name: Add flash script
+ env:
+ DOC: resources/how-to-flash.txt
+ FILES: ${{ format('{0}/{1}', env.BUILD, env.VARIANT) }}
+ run: |
+ BOARD=`echo $BOARD | tr '[:lower:]' '[:upper:]'`
+
+ # fix for docs
+ if [ "$BOARD" = "ESP32DEV" ]; then
+ BOARD="ESP32"
+ fi
+
+ # look for documentation on flash and copy the command
+ command=`sed -n '/^Howto flash (esptool)$/,$p' ${DOC} | sed -n '/^## '"${BOARD}"'$/,\${ n; n; p; }' | head -n1`
+
+ if [ -z "$command" ]; then
+ echo "::error::Command not found in document ${DOC} for board ${BOARD}"
+ exit 1
+ fi
+
+ echo -n "Command: "
+ echo "$command" | tee ${FILES}/flash.sh
+ chmod a+x ${FILES}/flash.sh
+
+ - name: Upload Artifact ${{ matrix.board }}-${{ matrix.build }}
+ uses: actions/upload-artifact@v4
+ with:
+ name: ${{ format('{0}-{1}-assets', env.VARIANT, matrix.build) }}
+ path: ${{ matrix.build }}/${{ env.VARIANT }}
+ ota-nightly:
+ name: Create nightly from latest master
+ needs: build
+ runs-on: ubuntu-latest
+ steps:
+ - name: Git Checkout
+ uses: actions/checkout@v4
+ with:
+ ref: ${{ github.head_ref }}
+ - name: Download release assets
+ uses: actions/download-artifact@v4
+ with:
+ path: release
+ pattern: '*-release-assets'
+ - name: Copy binaries to ota/master
+ run: |
+ mkdir -p ota/master/
+ cp -vf release/*/nuki_hub_*.bin ota/master/
+ rm -rf release
+ - name: Commit binaries to master
+ uses: stefanzweifel/git-auto-commit-action@v5
+ with:
+ commit_message: "Update master binaries"
+ file_pattern: 'ota/master/*.bin'
+ branch: master
+ skip_dirty_check: true
+ skip_fetch: true
+ skip_checkout: true
+ disable_globbing: true
+ add_options: '-f'
\ No newline at end of file
diff --git a/src/Config.h b/src/Config.h
index af6c0ec..b24b409 100644
--- a/src/Config.h
+++ b/src/Config.h
@@ -2,7 +2,7 @@
#include "sdkconfig.h"
-#define NUKI_HUB_VERSION "8.35"
+#define NUKI_HUB_VERSION "9.00"
#define NUKI_HUB_BUILD "unknownbuildnr"
#define GITHUB_LATEST_RELEASE_URL (char*)"https://github.com/technyon/nuki_hub/releases/latest"
@@ -13,27 +13,37 @@
#define GITHUB_LATEST_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_updater_esp32c3.bin"
#define GITHUB_BETA_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_esp32c3.bin"
#define GITHUB_BETA_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_updater_esp32c3.bin"
+#define GITHUB_MASTER_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_esp32c3.bin"
+#define GITHUB_MASTER_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_updater_esp32c3.bin"
#elif defined(CONFIG_IDF_TARGET_ESP32S3)
#define GITHUB_LATEST_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_esp32s3.bin"
#define GITHUB_LATEST_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_updater_esp32s3.bin"
#define GITHUB_BETA_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_esp32s3.bin"
#define GITHUB_BETA_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_updater_esp32s3.bin"
+#define GITHUB_MASTER_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_esp32s3.bin"
+#define GITHUB_MASTER_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_updater_esp32s3.bin"
#elif defined(CONFIG_IDF_TARGET_ESP32C6)
#define GITHUB_LATEST_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_esp32c6.bin"
#define GITHUB_LATEST_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_updater_esp32c6.bin"
#define GITHUB_BETA_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_esp32c6.bin"
#define GITHUB_BETA_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_updater_esp32c6.bin"
+#define GITHUB_MASTER_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_esp32c6.bin"
+#define GITHUB_MASTER_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_updater_esp32c6.bin"
#else
#if defined(FRAMEWORK_ARDUINO_SOLO1)
#define GITHUB_LATEST_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_esp32solo1.bin"
#define GITHUB_LATEST_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_updater_esp32solo1.bin"
#define GITHUB_BETA_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_esp32solo1.bin"
#define GITHUB_BETA_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_updater_esp32solo1.bin"
+#define GITHUB_MASTER_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_esp32solo1.bin"
+#define GITHUB_MASTER_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_updater_esp32solo1.bin"
#else
#define GITHUB_LATEST_RELEASE_BINARY_URL "https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_esp32.bin"
#define GITHUB_LATEST_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/nuki_hub_updater_esp32.bin"
#define GITHUB_BETA_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_esp32.bin"
#define GITHUB_BETA_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/beta/nuki_hub_updater_esp32.bin"
+#define GITHUB_MASTER_RELEASE_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_esp32.bin"
+#define GITHUB_MASTER_UPDATER_BINARY_URL (char*)"https://github.com/technyon/nuki_hub/raw/master/ota/master/nuki_hub_updater_esp32.bin"
#endif
#endif
diff --git a/src/WebCfgServer.cpp b/src/WebCfgServer.cpp
index 52a6b88..738da82 100644
--- a/src/WebCfgServer.cpp
+++ b/src/WebCfgServer.cpp
@@ -321,7 +321,7 @@ void WebCfgServer::initialize()
if (_hasCredentials && !_server.authenticate(_credUser, _credPassword)) {
return _server.requestAuthentication();
}
- String response = "";
+ String response = "";
String key = _server.argName(0);
if(key == "beta")
{
@@ -329,6 +329,12 @@ void WebCfgServer::initialize()
_preferences->putString(preference_ota_updater_url, GITHUB_BETA_UPDATER_BINARY_URL);
_preferences->putString(preference_ota_main_url, GITHUB_BETA_RELEASE_BINARY_URL);
}
+ else if(key == "master")
+ {
+ buildConfirmHtml(response, "Rebooting to update Nuki Hub and Nuki Hub updater
Updating to latest development version", 2);
+ _preferences->putString(preference_ota_updater_url, GITHUB_MASTER_UPDATER_BINARY_URL);
+ _preferences->putString(preference_ota_main_url, GITHUB_MASTER_RELEASE_BINARY_URL);
+ }
else
{
buildConfirmHtml(response, "Rebooting to update Nuki Hub and Nuki Hub updater
Updating to latest RELEASE version", 2);
@@ -397,7 +403,7 @@ void WebCfgServer::buildOtaHtml(String &response, bool errored)
if(_partitionType == 0)
{
- response.concat("