mirror of
https://github.com/buanet/ioBroker.docker.git
synced 2025-12-17 10:29:00 +02:00
add build tag
This commit is contained in:
156
.github/workflows/build-debian12-latest_sep.yml
vendored
156
.github/workflows/build-debian12-latest_sep.yml
vendored
@@ -7,8 +7,35 @@ on:
|
|||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
|
create-build-number:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
build_number: ${{ steps.generate-build-number.outputs.build_number }}
|
||||||
|
steps:
|
||||||
|
- name: Checkout repo
|
||||||
|
uses: actions/checkout@v4.1.7
|
||||||
|
with:
|
||||||
|
repository: 'buanet/ioBroker.docker'
|
||||||
|
token: ${{ secrets.ACTIONS_PAT }}
|
||||||
|
|
||||||
|
- name: Generate build number
|
||||||
|
id: generate-build-number
|
||||||
|
run: |
|
||||||
|
BUILD="$(date +"%Y%m%d.%H%M%S")"
|
||||||
|
echo "$BUILD" > .github/dependencies/.latest-build
|
||||||
|
echo "::set-output name=build_number::$BUILD"
|
||||||
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
|
|
||||||
|
- name: Commit latest release version
|
||||||
|
run: |
|
||||||
|
git config --global user.name 'buanet'
|
||||||
|
git config --global user.email 'info@buanet.de'
|
||||||
|
git commit -am "new build"
|
||||||
|
git push
|
||||||
|
|
||||||
build-latest-armv7-for-buanet:
|
build-latest-armv7-for-buanet:
|
||||||
name: Build latest armv7 image for buanet
|
name: Build latest armv7 image for buanet
|
||||||
|
needs: [create-build-number]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch latest release tag
|
- name: Fetch latest release tag
|
||||||
@@ -27,20 +54,20 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
# Set values in iobroker_startup.sh
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$BUILD/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
||||||
# Set values in Dockerfile
|
# Set values in Dockerfile
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$BUILD/" -e "s/\${BUILD}/$BUILD/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
||||||
|
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
@@ -71,11 +98,12 @@ jobs:
|
|||||||
push: true
|
push: true
|
||||||
platforms: linux/arm/v7
|
platforms: linux/arm/v7
|
||||||
tags: |
|
tags: |
|
||||||
buanet/iobroker:${{ env.version }}-armv7,
|
buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7,
|
||||||
ghcr.io/buanet/iobroker:${{ env.version }}-armv7,
|
ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7,
|
||||||
|
|
||||||
build-latest-arm64v8-for-buanet:
|
build-latest-arm64v8-for-buanet:
|
||||||
name: Build latest armv64v8 image for buanet
|
name: Build latest armv64v8 image for buanet
|
||||||
|
needs: [create-build-number]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch latest release tag
|
- name: Fetch latest release tag
|
||||||
@@ -94,20 +122,20 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
# Set values in iobroker_startup.sh
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$BUILD/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
||||||
# Set values in Dockerfile
|
# Set values in Dockerfile
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$BUILD/" -e "s/\${BUILD}/$BUILD/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
||||||
|
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
@@ -138,11 +166,12 @@ jobs:
|
|||||||
push: true
|
push: true
|
||||||
platforms: linux/arm64/v8
|
platforms: linux/arm64/v8
|
||||||
tags: |
|
tags: |
|
||||||
buanet/iobroker:${{ env.version }}-arm64v8,
|
buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8,
|
||||||
ghcr.io/buanet/iobroker:${{ env.version }}-arm64v8,
|
ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8,
|
||||||
|
|
||||||
build-latest-amd64-for-buanet:
|
build-latest-amd64-for-buanet:
|
||||||
name: Build latest amd64 image for buanet
|
name: Build latest amd64 image for buanet
|
||||||
|
needs: [create-build-number]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch latest release tag
|
- name: Fetch latest release tag
|
||||||
@@ -161,20 +190,20 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
# Set values in iobroker_startup.sh
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$BUILD/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
||||||
# Set values in Dockerfile
|
# Set values in Dockerfile
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$BUILD/" -e "s/\${BUILD}/$BUILD/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
@@ -202,8 +231,8 @@ jobs:
|
|||||||
push: true
|
push: true
|
||||||
platforms: linux/amd64
|
platforms: linux/amd64
|
||||||
tags: |
|
tags: |
|
||||||
buanet/iobroker:${{ env.version }}-amd64,
|
buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64,
|
||||||
ghcr.io/buanet/iobroker:${{ env.version }}-amd64,
|
ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64,
|
||||||
|
|
||||||
create-multiarch-image-for-buanet:
|
create-multiarch-image-for-buanet:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
@@ -225,21 +254,16 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
|
||||||
# Set values in Dockerfile
|
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
|
||||||
- name: Login to DockerHub (buanet)
|
- name: Login to DockerHub (buanet)
|
||||||
uses: docker/login-action@v3.3.0
|
uses: docker/login-action@v3.3.0
|
||||||
with:
|
with:
|
||||||
@@ -255,15 +279,18 @@ jobs:
|
|||||||
|
|
||||||
- name: Create and push multi-platform image
|
- name: Create and push multi-platform image
|
||||||
run: |
|
run: |
|
||||||
docker buildx imagetools create -t buanet/iobroker:latest buanet/iobroker:${{ env.version }}-armv7 buanet/iobroker:${{ env.version }}-arm64v8 buanet/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t buanet/iobroker:latest buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t ghcr.io/buanet/iobroker:latest ghcr.io/buanet/iobroker:${{ env.version }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t ghcr.io/buanet/iobroker:latest ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t buanet/iobroker:${{ env.majorversion }} buanet/iobroker:${{ env.version }}-armv7 buanet/iobroker:${{ env.version }}-arm64v8 buanet/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t buanet/iobroker:${{ env.majorversion }} buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t ghcr.io/buanet/iobroker:${{ env.majorversion }} ghcr.io/buanet/iobroker:${{ env.version }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t ghcr.io/buanet/iobroker:${{ env.majorversion }} ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t buanet/iobroker:${{ env.version }} buanet/iobroker:${{ env.version }}-armv7 buanet/iobroker:${{ env.version }}-arm64v8 buanet/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t buanet/iobroker:${{ env.version }} buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t ghcr.io/buanet/iobroker:${{ env.version }} ghcr.io/buanet/iobroker:${{ env.version }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t ghcr.io/buanet/iobroker:${{ env.version }} ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
|
docker buildx imagetools create -t buanet/iobroker:${{ env.version }}-build.${{ env.build }} buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
|
docker buildx imagetools create -t ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }} ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 ghcr.io/buanet/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
|
|
||||||
build-latest-armv7-for-iobroker:
|
build-latest-armv7-for-iobroker:
|
||||||
name: Build latest armv7 image for iobroker
|
name: Build latest armv7 image for iobroker
|
||||||
|
needs: [create-build-number]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch latest release tag
|
- name: Fetch latest release tag
|
||||||
@@ -282,20 +309,20 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
# Set values in iobroker_startup.sh
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$BUILD/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
||||||
# Set values in Dockerfile
|
# Set values in Dockerfile
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$BUILD/" -e "s/\${BUILD}/$BUILD/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
||||||
|
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
@@ -318,10 +345,11 @@ jobs:
|
|||||||
file: ./debian12/Dockerfile
|
file: ./debian12/Dockerfile
|
||||||
push: true
|
push: true
|
||||||
platforms: linux/arm/v7
|
platforms: linux/arm/v7
|
||||||
tags: iobroker/iobroker:${{ env.version }}-armv7
|
tags: iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-armv7
|
||||||
|
|
||||||
build-latest-arm64v8-for-iobroker:
|
build-latest-arm64v8-for-iobroker:
|
||||||
name: Build latest armv64v8 image for iobroker
|
name: Build latest armv64v8 image for iobroker
|
||||||
|
needs: [create-build-number]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch latest release tag
|
- name: Fetch latest release tag
|
||||||
@@ -340,20 +368,20 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
# Set values in iobroker_startup.sh
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$BUILD/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
||||||
# Set values in Dockerfile
|
# Set values in Dockerfile
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$BUILD/" -e "s/\${BUILD}/$BUILD/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
||||||
|
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
@@ -376,10 +404,11 @@ jobs:
|
|||||||
file: ./debian12/Dockerfile
|
file: ./debian12/Dockerfile
|
||||||
push: true
|
push: true
|
||||||
platforms: linux/arm64/v8
|
platforms: linux/arm64/v8
|
||||||
tags: iobroker/iobroker:${{ env.version }}-arm64v8
|
tags: iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8
|
||||||
|
|
||||||
build-latest-amd64-for-iobroker:
|
build-latest-amd64-for-iobroker:
|
||||||
name: Build latest amd64 image for iobroker
|
name: Build latest amd64 image for iobroker
|
||||||
|
needs: [create-build-number]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch latest release tag
|
- name: Fetch latest release tag
|
||||||
@@ -398,20 +427,20 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
# Set values in iobroker_startup.sh
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$BUILD/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
||||||
# Set values in Dockerfile
|
# Set values in Dockerfile
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$BUILD/" -e "s/\${BUILD}/$BUILD/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
@@ -431,7 +460,7 @@ jobs:
|
|||||||
file: ./debian12/Dockerfile
|
file: ./debian12/Dockerfile
|
||||||
push: true
|
push: true
|
||||||
platforms: linux/amd64
|
platforms: linux/amd64
|
||||||
tags: iobroker/iobroker:${{ env.version }}-amd64
|
tags: iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
|
|
||||||
create-multiarch-image-for-iobroker:
|
create-multiarch-image-for-iobroker:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
@@ -453,21 +482,15 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
VERSION="$(cat .VERSION)"
|
VERSION="$(cat .VERSION)"
|
||||||
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
MAJORVERSION="$(cat .VERSION | cut -c 1-3 | sed -r 's#^(.{0})#\1latest-#')"
|
||||||
DATI="$(date --rfc-3339=seconds | sed 's/ /T/')"
|
BUILD="${{ needs.create-build-number.outputs.build_number }}"
|
||||||
# Log output and export as Github environment variable
|
# Log output and export as Github environment variable
|
||||||
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
echo "[LOG] Nodejs Version: ${{ vars.RECOMMENDED_NODE_VERSION }}"
|
||||||
echo "[LOG] Image Version: $VERSION"
|
echo "[LOG] Image Version: $VERSION"
|
||||||
echo "version=$VERSION" >> $GITHUB_ENV
|
echo "version=$VERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Major Image Version: $MAJORVERSION"
|
echo "[LOG] Major Image Version: $MAJORVERSION"
|
||||||
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
echo "majorversion=$MAJORVERSION" >> $GITHUB_ENV
|
||||||
echo "[LOG] Buildnumber/Timestamp: $DATI"
|
echo "[LOG] Buildnumber: $BUILD"
|
||||||
echo "dati=$DATI" >> $GITHUB_ENV
|
echo "build=$BUILD" >> $GITHUB_ENV
|
||||||
# Set values in iobroker_startup.sh
|
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${BUILD}/$DATI/" ./debian12/scripts/iobroker_startup.sh > ./debian12/scripts/iobroker_startup.tmp
|
|
||||||
mv -f ./debian12/scripts/iobroker_startup.tmp ./debian12/scripts/iobroker_startup.sh
|
|
||||||
# Set values in Dockerfile
|
|
||||||
sed -e "s/\${VERSION}/$VERSION/" -e "s/\${DATI}/$DATI/" -e "s/\${NODE}/${{ vars.RECOMMENDED_NODE_VERSION }}/" ./debian12/Dockerfile > ./debian12/Dockerfile.tmp
|
|
||||||
mv -f ./debian12/Dockerfile.tmp ./debian12/Dockerfile
|
|
||||||
|
|
||||||
- name: Login to DockerHub (iobroker)
|
- name: Login to DockerHub (iobroker)
|
||||||
uses: docker/login-action@v3.3.0
|
uses: docker/login-action@v3.3.0
|
||||||
@@ -477,6 +500,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Create and push multi-platform image
|
- name: Create and push multi-platform image
|
||||||
run: |
|
run: |
|
||||||
docker buildx imagetools create -t iobroker/iobroker:latest iobroker/iobroker:${{ env.version }}-armv7 iobroker/iobroker:${{ env.version }}-arm64v8 iobroker/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t iobroker/iobroker:latest iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t iobroker/iobroker:${{ env.majorversion }} iobroker/iobroker:${{ env.version }}-armv7 iobroker/iobroker:${{ env.version }}-arm64v8 iobroker/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t iobroker/iobroker:${{ env.majorversion }} iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
docker buildx imagetools create -t iobroker/iobroker:${{ env.version }} iobroker/iobroker:${{ env.version }}-armv7 iobroker/iobroker:${{ env.version }}-arm64v8 iobroker/iobroker:${{ env.version }}-amd64
|
docker buildx imagetools create -t iobroker/iobroker:${{ env.version }} iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
|
docker buildx imagetools create -t iobroker/iobroker:${{ env.version }}-build.${{ env.build }} iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-armv7 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-arm64v8 iobroker/iobroker:${{ env.version }}-build.${{ env.build }}-amd64
|
||||||
|
|||||||
@@ -84,7 +84,7 @@ RUN apt-get update && apt-get upgrade -y \
|
|||||||
&& rm -rf /tmp/* /var/tmp/* /root/.cache/* /root/.npm/* /var/lib/apt/lists/*
|
&& rm -rf /tmp/* /var/tmp/* /root/.cache/* /root/.npm/* /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Default environment variables
|
# Default environment variables
|
||||||
ENV BUILD="${DATI}" \
|
ENV BUILD="${BUILD}" \
|
||||||
DEBIAN_FRONTEND="teletype" \
|
DEBIAN_FRONTEND="teletype" \
|
||||||
LANG="de_DE.UTF-8" \
|
LANG="de_DE.UTF-8" \
|
||||||
LANGUAGE="de_DE:de" \
|
LANGUAGE="de_DE:de" \
|
||||||
|
|||||||
Reference in New Issue
Block a user