mirror of
https://github.com/buanet/ioBroker.docker.git
synced 2025-12-17 18:39:01 +02:00
Compare commits
17 Commits
v8.0.1
...
v8.1.0-bet
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
721c108742 | ||
|
|
7a455952dd | ||
|
|
a04f210190 | ||
|
|
0f59839695 | ||
|
|
4f15a4df23 | ||
|
|
686b391119 | ||
|
|
d5a6596070 | ||
|
|
8c9279b867 | ||
|
|
065d0cb4df | ||
|
|
acad72922e | ||
|
|
8fe4d775f5 | ||
|
|
e283d25710 | ||
|
|
893908f29d | ||
|
|
16e30c392d | ||
|
|
a954b51223 | ||
|
|
6a55923669 | ||
|
|
bbac132f28 |
@@ -1,5 +1,14 @@
|
|||||||
## Changelog
|
## Changelog
|
||||||
|
|
||||||
|
### v8.1.0-beta.2 (coming soon)
|
||||||
|
* prohibit restore when startup script is still running
|
||||||
|
* extend time before restart after restore is done
|
||||||
|
* v8.1.0-beta.1 (14.04.2023)
|
||||||
|
* enhance github actions
|
||||||
|
* enhance log output of maintenance script on restore ([#333](https://github.com/buanet/ioBroker.docker/issues/333))
|
||||||
|
* allow iobroker admin to be disabled at startup ([#332](https://github.com/buanet/ioBroker.docker/issues/332))
|
||||||
|
* allow deletion of objects and states db password with value "none" ([#306](https://github.com/buanet/ioBroker.docker/issues/306))
|
||||||
|
|
||||||
### v8.0.1 (17.04.2023)
|
### v8.0.1 (17.04.2023)
|
||||||
* fix calling of "iob setup first" on slaves ([#335](https://github.com/buanet/ioBroker.docker/issues/335))
|
* fix calling of "iob setup first" on slaves ([#335](https://github.com/buanet/ioBroker.docker/issues/335))
|
||||||
|
|
||||||
|
|||||||
3
debian/scripts/iobroker_startup.sh
vendored
3
debian/scripts/iobroker_startup.sh
vendored
@@ -143,9 +143,10 @@ if [[ -f /opt/.first_run ]]; then
|
|||||||
echo "PACKAGES is set, but OFFLINE_MODE is \"true\". Skipping Linux package installation."
|
echo "PACKAGES is set, but OFFLINE_MODE is \"true\". Skipping Linux package installation."
|
||||||
elif [[ "$packages" != "" ]]; then
|
elif [[ "$packages" != "" ]]; then
|
||||||
echo "PACKAGES is set. Installing the following additional Linux packages: ""$packages"
|
echo "PACKAGES is set. Installing the following additional Linux packages: ""$packages"
|
||||||
echo "$packages" > /opt/scripts/.docker_config/.packages
|
# echo "$packages" > /opt/scripts/.docker_config/.packages
|
||||||
bash /opt/scripts/setup_packages.sh -install
|
bash /opt/scripts/setup_packages.sh -install
|
||||||
fi
|
fi
|
||||||
|
echo ' '
|
||||||
# Register maintenance script
|
# Register maintenance script
|
||||||
echo -n 'Registering maintenance script as command... '
|
echo -n 'Registering maintenance script as command... '
|
||||||
echo "alias maintenance=\'/opt/scripts/maintenance.sh\'" >> /root/.bashrc
|
echo "alias maintenance=\'/opt/scripts/maintenance.sh\'" >> /root/.bashrc
|
||||||
|
|||||||
25
debian/scripts/maintenance.sh
vendored
25
debian/scripts/maintenance.sh
vendored
@@ -38,6 +38,11 @@ maintenance_enabled() {
|
|||||||
[[ -f "$healthcheck" && "$(cat "$healthcheck")" == maintenance ]]
|
[[ -f "$healthcheck" && "$(cat "$healthcheck")" == maintenance ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# check status starting
|
||||||
|
check_starting() {
|
||||||
|
[[ -f "$healthcheck" && "$(cat "$healthcheck")" == starting ]]
|
||||||
|
}
|
||||||
|
|
||||||
# display maintenance status
|
# display maintenance status
|
||||||
maintenance_status() {
|
maintenance_status() {
|
||||||
if maintenance_enabled; then
|
if maintenance_enabled; then
|
||||||
@@ -221,6 +226,8 @@ restart_container() {
|
|||||||
# restore iobroker
|
# restore iobroker
|
||||||
restore_iobroker() {
|
restore_iobroker() {
|
||||||
echo 'You are now going to perform a restore of your iobroker.'
|
echo 'You are now going to perform a restore of your iobroker.'
|
||||||
|
echo 'During the restore process, the container will automatically switch into maintenance mode and stop ioBroker.'
|
||||||
|
echo 'Depending on the restart policy, your container will be stopped or restarted automatically after the restore.'
|
||||||
|
|
||||||
if [[ "$autoconfirm" != yes ]]; then
|
if [[ "$autoconfirm" != yes ]]; then
|
||||||
local reply
|
local reply
|
||||||
@@ -235,11 +242,17 @@ restore_iobroker() {
|
|||||||
echo 'This command was already confirmed by the -y or --yes option.'
|
echo 'This command was already confirmed by the -y or --yes option.'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -n 'Stopping ioBroker...'
|
if check_starting > /dev/null; then
|
||||||
stop_iob
|
echo "Startup script is still running."
|
||||||
|
echo "Please check container log and wait until ioBroker is sucessfully started."
|
||||||
|
echo "Then try again."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
# fixing permission errors during restore
|
if ! maintenance_enabled > /dev/null; then
|
||||||
#chown -R $setuid:$setgid /opt/iobroker/backup
|
autoconfirm=yes
|
||||||
|
enable_maintenance
|
||||||
|
fi
|
||||||
|
|
||||||
echo -n "Restoring ioBroker... "
|
echo -n "Restoring ioBroker... "
|
||||||
set +e
|
set +e
|
||||||
@@ -263,8 +276,8 @@ restore_iobroker() {
|
|||||||
echo "!!!! You can view installation process by taking a look at ioBroker log. !!!!"
|
echo "!!!! You can view installation process by taking a look at ioBroker log. !!!!"
|
||||||
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
|
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
|
||||||
sleep 10
|
sleep 10
|
||||||
echo 'Container will be stopped or restarted in 5 seconds...'
|
echo 'Container will be stopped or restarted in 10 seconds...'
|
||||||
sleep 5
|
sleep 10
|
||||||
echo 'stopping' > "$healthcheck"
|
echo 'stopping' > "$healthcheck"
|
||||||
pkill -u root
|
pkill -u root
|
||||||
}
|
}
|
||||||
|
|||||||
85
debian/scripts/setup_packages.sh
vendored
85
debian/scripts/setup_packages.sh
vendored
@@ -1,36 +1,69 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# bash strict mode
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Reading ENV
|
||||||
|
set +u
|
||||||
|
packages=$PACKAGES
|
||||||
|
debug=$DEBUG
|
||||||
|
set -u
|
||||||
|
|
||||||
export DEBIAN_FRONTEND=noninteractive
|
export DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
if [ "$1" == "-install" ]
|
check_package_preq() {
|
||||||
then
|
# check for influx packages
|
||||||
apt-get -q update >> /opt/scripts/setup_packages.log 2>&1
|
if [[ "$i" == "influxdb" || "$i" == "influxdb2-cli" ]]; then
|
||||||
packages=$(cat /opt/scripts/.docker_config/.packages)
|
# add influxdata repo keys
|
||||||
echo ' '
|
wget -qO- https://repos.influxdata.com/influxdata-archive_compat.key | gpg --dearmor | sudo tee /etc/apt/trusted.gpg.d/influxdata-archive_compat.gpg > /dev/null
|
||||||
for i in $packages; do
|
echo 'deb [signed-by=/etc/apt/trusted.gpg.d/influxdata-archive_compat.gpg] https://repos.influxdata.com/debian stable main' | sudo tee /etc/apt/sources.list.d/influxdata.list
|
||||||
if [ "$(dpkg-query -W -f='${Status}' "$i" 2>/dev/null | grep -c "ok installed")" -eq 0 ];
|
apt-get -q update >> /opt/scripts/setup_packages.log 2>&1
|
||||||
then
|
fi
|
||||||
echo -n "$i is not installed. Installing... "
|
}
|
||||||
DEBIAN_FRONTEND=noninteractive apt-get -q -y install "$i" >> /opt/scripts/setup_packages.log 2>&1
|
check_package_validity() {
|
||||||
return=$?
|
# check string for double spaces
|
||||||
if [[ "$return" -ne 0 ]]; then
|
while echo "$packages" | grep -q ' '; do
|
||||||
echo "Failed."
|
packages=$(echo "$packages" | sed 's/ / /g')
|
||||||
echo "For more details see \"/opt/scripts/setup_packages.log\"."
|
|
||||||
echo ' '
|
|
||||||
else
|
|
||||||
echo "Done."
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "$i is already installed."
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
elif [ "$1" == "-update" ]; then
|
# remove packages when "influxdb" AND "influxdb2-cli"
|
||||||
|
if echo "$packages" | grep -qw "influxdb" && echo "$packages" | grep -qw "influxdb2-cli"; then
|
||||||
|
echo "PACKAGES includes influxdb AND influxdb2-cli."
|
||||||
|
echo "As installing both packages together is not possible, they will be skipped."
|
||||||
|
packages=$(echo "$packages" | sed 's/influxdb2-cli//g;s/influxdb//g')
|
||||||
|
# check string for double spaces again
|
||||||
|
while echo "$packages" | grep -q ' '; do
|
||||||
|
packages=$(echo "$packages" | sed 's/ / /g')
|
||||||
|
done
|
||||||
|
if [[ $debug == "true" ]]; then echo "[DEBUG] New list of packages: ""$packages"; fi
|
||||||
|
echo ' '
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ "$1" == "-install" ]]; then
|
||||||
|
echo ' '
|
||||||
|
apt-get -q update >> /opt/scripts/setup_packages.log 2>&1
|
||||||
|
check_package_validity
|
||||||
|
for i in $packages; do
|
||||||
|
if ! dpkg -s "$i" >/dev/null 2>&1; then
|
||||||
|
echo -n "$i is not installed. Installing... "
|
||||||
|
check_package_preq >> /opt/scripts/setup_packages.log 2>&1
|
||||||
|
if ! apt-get -q -y install "$i" >> /opt/scripts/setup_packages.log 2>&1; then
|
||||||
|
echo "Failed."
|
||||||
|
echo "For more details see \"/opt/scripts/setup_packages.log\"."
|
||||||
|
else
|
||||||
|
echo "Done."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "$i is already installed."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
elif [[ "$1" == "-update" ]]; then
|
||||||
echo -n "Updating Linux packages on first run... "
|
echo -n "Updating Linux packages on first run... "
|
||||||
apt-get -q update >> /opt/scripts/setup_packages.log 2>&1
|
apt-get -q update >> /opt/scripts/setup_packages.log 2>&1
|
||||||
return=$?
|
|
||||||
apt-get -q -y upgrade >> /opt/scripts/setup_packages.log 2>&1
|
|
||||||
return1=$?
|
return1=$?
|
||||||
if [[ "$return" -ne 0 || "$return1" -ne 0 ]]; then
|
apt-get -q -y upgrade >> /opt/scripts/setup_packages.log 2>&1
|
||||||
|
return2=$?
|
||||||
|
if [[ "$return1" -ne 0 || "$return2" -ne 0 ]]; then
|
||||||
echo "Failed."
|
echo "Failed."
|
||||||
echo "For more details see \"/opt/scripts/setup_packages.log\"."
|
echo "For more details see \"/opt/scripts/setup_packages.log\"."
|
||||||
echo "Make sure the container has internet access to get the latest package updates."
|
echo "Make sure the container has internet access to get the latest package updates."
|
||||||
@@ -47,4 +80,4 @@ fi
|
|||||||
apt-get -qq autoclean -y && apt-get -qq autoremove && apt-get -qq clean
|
apt-get -qq autoclean -y && apt-get -qq autoremove && apt-get -qq clean
|
||||||
rm -rf /tmp/* /var/tmp/* && rm -rf /root/.cache/* && rm -rf /var/lib/apt/lists/* && rm -f /opt/scripts/.docker_config/.packages
|
rm -rf /tmp/* /var/tmp/* && rm -rf /root/.cache/* && rm -rf /var/lib/apt/lists/* && rm -f /opt/scripts/.docker_config/.packages
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
Reference in New Issue
Block a user