diff --git a/.VERSION b/.VERSION index 55491a8..03b253c 100644 --- a/.VERSION +++ b/.VERSION @@ -1 +1 @@ -v3.1.2beta +v3.1.4beta \ No newline at end of file diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..885322b --- /dev/null +++ b/.travis.yml @@ -0,0 +1,105 @@ +sudo: required + +branches: + only: + - master + - beta + +services: + - docker + +language: bash + +env: + global: + - secure: "iqK7JBsQiYceKOvRkmSa6okzXn3BygEPZjffby4agaVCwIt2SYLAcBOisOoKDpyAX+DUWlHz3gITImVa+uIna6Ue7k4C2AGJVDr87G6iq57Tn6yjrfhPs/TW9/CWvKg/G4uvKEnycMiLDXdcctSMwRr3ZwzJEdeEdmNZVsd2LP/5U0I/2K2Io22tNciSKhqlSaIfhK4f6Jk7xffnQFjwy+P9qPN18oI1fDyeHx6ZWyN3YhQQ4eGyxHjxZjlhCxSvu5R4DMf1jFIoLRAr6G5jrQacn0pG8PtBVLoYT4RsPy+fwUtXmnWWjeXK0IrU1njZf/DUteI9xnaDcHzZYj+d7MeSUc6BuWOyx9lO3ZwBWDNycYsKaF5so4RpdzoY/gfJMlK3uWDbADb46dWzPD5gb3pEROKau3fBDHS5eaR5e1Bxzz6FGoYWYfsQHqpg9g7v4BRFq+Jh0+v47fdyMxgK/Nm4+r7+ht77Usu29+X6X8F4iwrBJ/ix5xIf7iMoH/ZGvq6BEKi/1t9zdXMugcWOqwlYx9k6J9bQhBfw8YucLmgl3ynzrPaLlPEpY9cnb7hcOUDZoHI7KK2zF/y3yfNr2BqlRbm39HFWfnwuJPO5VLYGs5QubeVj9u1M+5Qo4erPuQBBc4mHP4eF2PmRA+wiVWki0z+U2skFQppkCfrbH8c=" + - secure: "iqoZUcWgZueNQrNldF/ugwyU1LR5E+doTfjY0exQqAKjntG5n2QqYZ/+dX1gqvkfy1kuMINTBWfqSALbhfTTK7EfUjqmcnaks4CMVZQkhH/FyCOYHqSBSSN7j4XeHt1sXn1FRiSpyrZOUoOuyqoBRe3JoWhdQZAGxNzX3sJllwnKa6M0D6D2l9tUyTWO/jxhgTIoYBSrXvb68ZsCU9jlNBJbylfvEFwuSlwvfa+Mz9vAeCTuza9XDnvcxgwVq3r+YGxfmAhK9fOAvN+lPN+KA0LcIzBaW0sh24voqjfh/pLpsl03zeGNdWzS9r2qYPCP0N3asb5P6CVEbbAGYO1T5PvU78ILXGi4+/x/32O6/I9oXpMVQCFHNn0Gn/8BPRHY4ZOYI9ItnhV9Ncp7hhAWAAqf3KC5GM89l9R5KxFY3bhN/p8nuGresUDU5d57YkaV8rOhPpr0dbAyKFtuzG0+bT1N2ekXyTyMHeAGKiGwfD9bAS4qx6asFO5uw6UriBHNzJ59Cy3GT+W1CctaEuvqJlc6Iqz2KaBozEqnNFcpE2Grny4bzr5fp+b1qCO9TE2LhHU/LR5FTLjQ2wf9/raTM6yboq+guKeXxpySa2w8ABDq0OUAw4mrKqJQJohzBkl3oYTpWUG2JGEyMAJxjkmH0/3GwZESPNLaaYVjQByTDDY=" + - VERSION="$(cat .VERSION)" + +before_install: + - wget https://github.com/estesp/manifest-tool/releases/download/v0.7.0/manifest-tool-linux-amd64 -O manifest-tool + - chmod +x manifest-tool + - docker run --rm --privileged multiarch/qemu-user-static:register + - echo "$HUB_PASS" | docker login -u "$HUB_USER" --password-stdin + +jobs: + include: + - stage: Build images + env: + - ARCH=amd64 + - JOB_NAME="Build images" + script: + - sed -i "s/\$VERSION/${VERSION}/g" $ARCH/scripts/iobroker_startup.sh + - docker build -t "buanet/iobroker:$VERSION-$ARCH" ./amd64 + + - stage: Build images + env: + - ARCH=aarch64 + - JOB_NAME="Build images" + script: + - docker run --rm --privileged multiarch/qemu-user-static:register --reset + - sed -i "s/\$VERSION/${VERSION}/g" $ARCH/scripts/iobroker_startup.sh + - docker build -t "buanet/iobroker:$VERSION-$ARCH" ./aarch64 + + - stage: Build images + env: + - ARCH=armv7hf + - JOB_NAME="Build images" + script: + - docker run --rm --privileged multiarch/qemu-user-static:register --reset + - sed -i "s/\$VERSION/${VERSION}/g" $ARCH/scripts/iobroker_startup.sh + - docker build -t "buanet/iobroker:$VERSION-$ARCH" ./armv7hf + + - stage: Manifest + env: + - JOB_NAME="Manifest" + script: + - echo Placeholder + +after_success: +# tag and push built images + - > + if [ "$TRAVIS_BRANCH" == "master" ] && [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$JOB_NAME" == "Build images" ] ; then + docker push buanet/iobroker:$VERSION-$ARCH + fi + + if [ "$TRAVIS_BRANCH" == "beta" ] && [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$JOB_NAME" == "Build images" ] ; then + docker push buanet/iobroker:$VERSION-$ARCH + fi + +# update repository manifest for multiarch and push to hub + - > + if [ "$TRAVIS_BRANCH" == "master" ] && [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$JOB_NAME" == "Manifest" ]; then + cat manifest.yml | sed "s/\$VERSION/${VERSION}/g" > manifest.yaml + + #manifest for image: buanet/iobroker:version + cat manifest.yaml | sed "s/\$DOCKERTAG/${VERSION}/g" > manifestversion.yaml + + #manifest for image: buanet/iobroker:latest + cat manifest.yaml | sed "s/\$DOCKERTAG/latest/g" > manifestlatest.yaml + + #push to hub + mv manifestversion.yaml iobroker.yaml + ./manifest-tool --username $HUB_USER --password $HUB_PASS push from-spec iobroker.yaml + + mv manifestlatest.yaml iobroker.yaml + ./manifest-tool --username $HUB_USER --password $HUB_PASS push from-spec iobroker.yaml + fi + + if [ "$TRAVIS_BRANCH" == "beta" ] && [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$JOB_NAME" == "Manifest" ]; then + + cat manifest.yml | sed "s/\$VERSION/${VERSION}/g" > manifest.yaml + + #manifest for image: buanet/iobroker:version + cat manifest.yaml | sed "s/\$DOCKERTAG/${VERSION}/g" > manifestversion.yaml + + #manifest for image: buanet/iobroker:beta + cat manifest.yaml | sed "s/\$DOCKERTAG/beta/g" > manifestbeta.yaml + + #push to hub + mv manifestversion.yaml iobroker.yaml + ./manifest-tool --username $HUB_USER --password $HUB_PASS push from-spec iobroker.yaml + + mv manifestbeta.yaml iobroker.yaml + ./manifest-tool --username $HUB_USER --password $HUB_PASS push from-spec iobroker.yaml + fi diff --git a/LICENSE.md b/LICENSE.md index 7d7efd3..afe63aa 100644 --- a/LICENSE.md +++ b/LICENSE.md @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2017 [André Germann] +Copyright (c) 2017 Andre Germann Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index 073664d..104f628 100644 --- a/README.md +++ b/README.md @@ -1,23 +1,33 @@ -# docker-iobroker -Docker image for ioBroker (http://iobroker.net) based on debian:stretch (http://hub.docker.com/_/debian/) +# ioBroker for Docker +Source: https://github.com/buanet/docker-iobroker -This project creates a Docker image for running ioBroker in a Docker container. It is made for and tested on a Synology Disk Station 1515+ with DSM 6 and Docker-package installed. But it should also work on other systems with Docker installed! +IoBroker for Docker is an Dockerimage for ioBroker (http://iobroker.net) smarthome software. + +It is originally made for, and tested on a Synology Disk Station 1515+ with DSM 6 and Docker-package installed. But it should also work on other systems with Docker installed! + +Version 4 (coming soon, at the moment still as 3.1.4beta) now supports running the Image in Docker on the following architectures: amd64, armv7hf, aarch64. +Feel free to ask for more architectures by opening an github-issue. ## Important -Switching an existing installation from docker-iobroker-image v1 to v2 or greater means switching iobroker itself from node6 to node8! This requires additional steps inside ioBroker! After upgrading iobroker-container you have to call "reinstall.sh" for recompiling your installation for the use with node8. For Details see official ioBroker-documentation (http://www.iobroker.net/docu/?page_id=8323&lang=de). Make backup first!!! +The new v4 (coming soon, at the moment still as 3.1.4beta) comes again with a new major node-version (node10)! +If you are updating an existing Installation you have to perform some additional steps inside ioBroker! +After upgrading your iobroker-container you have to call "reinstall.sh" for recompiling your installation for the use with node10! +For Details see official ioBroker-documentation (http://www.iobroker.net/docu/?page_id=8323&lang=de). Make backup first! -## Installation & Usage +## Installation & usage -A detailed tutorial (german, based on new v3.0.0) can be found here: [https://buanet.de](https://buanet.de/2019/05/iobroker-unter-docker-auf-der-synology-diskstation-v3/). Please notice that the old tutorial does no longer work! +A detailed tutorial (german, based on v3.0.0) can be found here: [https://buanet.de](https://buanet.de/2019/05/iobroker-unter-docker-auf-der-synology-diskstation-v3/). Please notice that the old tutorial is outdated and does no longer work! For discussion and support please visit [ioBroker-forum-thread](http://forum.iobroker.net/viewtopic.php?f=17&t=5089) or use the comments section at the linked tutorial. Please do not contact me directly for any support-reasons. Every support-question should be answered in a public place. Thank you. -## Special Settings +## Special settings and features -In v3.0.0 I added some new features. The following will give some short information about that. +The following will give a short overview. -### Environment Variables +### Environment variables + +Since v3 is possible to set some environment variables to configure a new container. |env|value|description| |---|---|---| @@ -29,10 +39,11 @@ In v3.0.0 I added some new features. The following will give some short informat |TZ|Europe/Berlin|all valid Linux-timezones| |SETUID|1000|for security reasons it might be useful to specify the uid of the containers iobroker user to match an existing user on the docker host| |SETGID|1000|for security reasons it might be useful to specify the gid of the containers iobroker user to match an existing group on the docker host| +|ZWAVE|false|will install openzwave to support zwave-adapter| ### Mounting Folder/ Volume -It is now possible to mount an empty folder to /opt/iobroker during first startup of the container. The Startupscript will check this folder and restore content if empty. +It is now possible to mount an empty folder to /opt/iobroker during first startup of the container. The Startupscript will check this folder and restore content if it is empty. It is absolutely recommended to use a mounted folder or persistent volume for /opt/iobroker folder! @@ -40,11 +51,16 @@ This also works with mounting a folder containing an existing ioBroker-installat ### Permission Fixer -I added some code for fixing permissions for new iobroker-user. Permission-fixing is called on first start of the container. This might take a few minutes. Please take a look at the logs and be patient! +After some issues with permissions related to the use of a dedicated user for ioBroker, I added some code for fixing permissions on container startup. This might take a few minutes on first startup. Please take a look at the logs and be patient! ## Changelog -### v3.1.2beta (2019-09-03) +### v3.1.4beta (2019-10-23) + * added env for zwave support +* v3.1.3beta (2019-10-17) + * enhanced logging of startup-script + * multiarch support (amd64, aarch64, armv7hf) +* v3.1.2beta (2019-09-03) * using node 10 instead of node 8 * v3.1.1beta (2019-09-02) * adding env for setting uid/ gid for iobroker-user diff --git a/aarch64/Dockerfile b/aarch64/Dockerfile new file mode 100644 index 0000000..69f7db8 --- /dev/null +++ b/aarch64/Dockerfile @@ -0,0 +1,84 @@ +FROM balenalib/aarch64-debian:stretch + +MAINTAINER Andre Germann + +ENV DEBIAN_FRONTEND noninteractive + +# Install prerequisites +RUN apt-get update && apt-get upgrade -y && apt-get install -y \ + acl \ + apt-utils \ + build-essential \ + curl \ + git \ + gnupg2 \ + libcap2-bin \ + libpam0g-dev \ + libudev-dev \ + locales \ + procps \ + python \ + gosu \ + unzip \ + wget \ + && rm -rf /var/lib/apt/lists/* + +# Install node10 +RUN curl -sL https://deb.nodesource.com/setup_10.x | bash \ + && apt-get update && apt-get install -y \ + nodejs \ + && rm -rf /var/lib/apt/lists/* + +# Generating locales +RUN sed -i 's/^# *\(de_DE.UTF-8\)/\1/' /etc/locale.gen \ + && sed -i 's/^# *\(en_US.UTF-8\)/\1/' /etc/locale.gen \ + && locale-gen + +# Create scripts directory and copy scripts +RUN mkdir -p /opt/scripts/ \ + && chmod 777 /opt/scripts/ +WORKDIR /opt/scripts/ +COPY scripts/iobroker_startup.sh iobroker_startup.sh +COPY scripts/setup_avahi.sh setup_avahi.sh +COPY scripts/setup_packages.sh setup_packages.sh +COPY scripts/setup_zwave.sh setup_zwave.sh +RUN chmod +x iobroker_startup.sh \ + && chmod +x setup_avahi.sh \ + && chmod +x setup_packages.sh + +# Install ioBroker +WORKDIR / +RUN apt-get update \ + && curl -sL https://raw.githubusercontent.com/ioBroker/ioBroker/stable-installer/installer.sh | bash - \ + && echo $(hostname) > /opt/iobroker/.install_host \ + && echo $(hostname) > /opt/.firstrun \ + && rm -rf /var/lib/apt/lists/* + +# Install node-gyp +WORKDIR /opt/iobroker/ +RUN npm config set unsafe-perm true # To fix "Error: could not get uid/gid" +RUN npm install -g node-gyp + +# Backup initial ioBroker-folder +RUN tar -cf /opt/initial_iobroker.tar /opt/iobroker + +# Setting up iobroker-user +RUN chsh -s /bin/bash iobroker + +# Setting up ENVs +ENV DEBIAN_FRONTEND="teletype" \ + LANG="de_DE.UTF-8" \ + LANGUAGE="de_DE:de" \ + LC_ALL="de_DE.UTF-8" \ + TZ="Europe/Berlin" \ + PACKAGES="nano" \ + AVAHI="false" \ + SETUID=1000 \ + SETGID=1000 \ + ZWAVE="false" + +# Setting up EXPOSE for Admin +EXPOSE 8081/tcp + +# Run startup-script +ENTRYPOINT ["/opt/scripts/iobroker_startup.sh"] diff --git a/aarch64/scripts/iobroker_startup.sh b/aarch64/scripts/iobroker_startup.sh new file mode 100644 index 0000000..68e9537 --- /dev/null +++ b/aarch64/scripts/iobroker_startup.sh @@ -0,0 +1,176 @@ +#!/bin/bash + +# Reading ENV +packages=$PACKAGES +avahi=$AVAHI +uid=$SETUID +gid=$SETGID +zwave=$ZWAVE + +# Getting date and time for logging +dati=`date '+%Y-%m-%d %H:%M:%S'` + +# Header +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo -n "$(printf -- '-%.0s' {1..15})" && echo -n " "$dati" " && echo "$(printf -- '-%.0s' {1..15})" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Welcome to your ioBroker-container! -----" +echo "----- Startupscript is now running. -----" +echo "----- Please be patient! -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Debugging information -----" +echo "----- -----" +echo "----- System -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" arch: $(uname -m))" && echo " -----" +echo "----- -----" +echo "----- Versions -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" image: $VERSION)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" node: $(node -v))" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" npm: $(npm -v))" && echo " -----" +echo "----- -----" +echo "----- ENV -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" AVAHI: $AVAHI)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" PACKAGES: $PACKAGES)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" SETGID: $SETGID)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" SETUID: $SETUID)" && echo " -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +# Checking and installing additional packages +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 1 of 5: Installing additional packages -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +if [ "$packages" != "" ] +then + echo "The following packages will be installed:" $packages"..." + echo $packages > /opt/scripts/.packages + sh /opt/scripts/setup_packages.sh > /opt/scripts/setup_packages.log 2>&1 + echo "Done." +else + echo "There are no additional packages defined." +fi +echo ' ' + +# Change directory for next steps +cd /opt/iobroker + +# Detecting ioBroker-Installation +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 2 of 5: Detecting ioBroker installation -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +if [ `ls -1a|wc -l` -lt 3 ] +then + echo "There is no data detected in /opt/iobroker. Restoring..." + tar -xf /opt/initial_iobroker.tar -C / + echo "Done." +else + if [ -f /opt/iobroker/iobroker ] + then + echo "Installation of ioBroker detected in /opt/iobroker." + else + echo "There is data detected in /opt/iobroker, but it looks like it is no instance of iobroker!" + echo "Please check/ recreate mounted folder/ volume and restart ioBroker container." + exit 1 + fi +fi +echo ' ' + +# Checking ioBroker-Installation +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 3 of 5: Checking ioBroker installation -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +# Checking for first run and set uid/gid +if [ -f /opt/.firstrun ] +then + echo "This is the first run of a new container. Time for some preparation." + echo ' ' + echo "Changing UID to "$uid" and GID to "$gid"..." + usermod -u $uid iobroker + groupmod -g $gid iobroker + rm -f /opt/.firstrun + echo "Done." +else + echo "This is NOT the first run of the container. Some Steps will be skipped." +fi +echo ' ' + +# (Re)Setting permissions to "/opt/iobroker" and "/opt/scripts" +echo "(Re)Setting folder permissions (This might take a while! Please be patient!)..." + chown -R $uid:$gid /opt/iobroker + chown -R $uid:$gid /opt/scripts +echo "Done." +echo ' ' + +# Backing up original iobroker-file and changing sudo to gosu +echo "Fixing \"sudo-bug\" by replacing sudo with gosu..." + cp -a /opt/iobroker/iobroker /opt/iobroker/iobroker.bak + chmod 755 /opt/iobroker/iobroker + sed -i 's/sudo -H -u/gosu/g' /opt/iobroker/iobroker +echo "Done." +echo ' ' + +# Checking for first run of a new installation and renaming ioBroker +if [ -f /opt/iobroker/.install_host ] +then + echo "Looks like this is a new and empty installation of ioBroker." + echo "Hostname needs to be updated to " $(hostname)"..." + sh /opt/iobroker/iobroker host $(cat /opt/iobroker/.install_host) + rm -f /opt/iobroker/.install_host + echo 'Done.' + echo ' ' +fi + +# Setting up prerequisites for some ioBroker-adapters +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 4 of 5: Applying special settings -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +echo "Some adapters have special requirements which can be activated by the use of environment variables." +echo "For more information take a look at readme.md" +echo ' ' + +# Checking for and setting up avahi-daemon +if [ "$avahi" = "true" ] +then + echo "Avahi-daemon is activated by ENV." + chmod 764 /opt/scripts/setup_avahi.sh + sh /opt/scripts/setup_avahi.sh + echo "Done." + echo ' ' +fi + +if [ "$zwave" = "true" ] +then + echo "ZWave is activated by ENV." + chmod 764 /opt/scripts/setup_zwave.sh + sh /opt/scripts/setup_zwave.sh + echo "Done." + echo ' ' +fi + +sleep 5 + +# Starting ioBroker +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 5 of 5: ioBroker startup -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "Starting ioBroker..." +echo ' ' +#gosu iobroker node --trace-warnings node_modules/iobroker.js-controller/controller.js > /opt/iobroker/iobroker.log 2>&1 & +gosu iobroker node node_modules/iobroker.js-controller/controller.js + +# Preventing container restart by keeping a process alive even if iobroker will be stopped +tail -f /dev/null diff --git a/scripts/setup_avahi.sh b/aarch64/scripts/setup_avahi.sh similarity index 67% rename from scripts/setup_avahi.sh rename to aarch64/scripts/setup_avahi.sh index 469331b..2f64a72 100644 --- a/scripts/setup_avahi.sh +++ b/aarch64/scripts/setup_avahi.sh @@ -1,18 +1,18 @@ #!/bin/bash -echo 'Checking avahi-daemon installation state...' +echo "Checking avahi-daemon installation state..." if [ -f /usr/sbin/avahi-daemon ] then - echo 'Avahi already installed...' + echo "Avahi is already installed..." else - echo 'Installing avahi-daemon...' + echo "Avahi-daemon is NOT installed. Going to install it now..." apt-get update > /opt/scripts/avahi_startup.log 2>&1 apt-get install -y libavahi-compat-libdnssd-dev avahi-daemon >> /opt/scripts/avahi_startup.log 2>&1 rm -rf /var/lib/apt/lists/* >> /opt/scripts/avahi_startup.log 2>&1 - echo 'Configuring avahi-daemon...' + echo "Configuring avahi-daemon..." sed -i '/^rlimit-nproc/s/^\(.*\)/#\1/g' /etc/avahi/avahi-daemon.conf - echo 'Configuring dbus...' + echo "Configuring dbus..." mkdir /var/run/dbus/ fi @@ -26,10 +26,10 @@ then rm -f /var/run/avahi-daemon//pid fi -echo 'Starting dbus...' +echo "Starting dbus..." dbus-daemon --system -echo 'Starting avahi-daemon...' +echo "Starting avahi-daemon..." /etc/init.d/avahi-daemon start exit 0 diff --git a/scripts/setup_packages.sh b/aarch64/scripts/setup_packages.sh similarity index 100% rename from scripts/setup_packages.sh rename to aarch64/scripts/setup_packages.sh diff --git a/aarch64/scripts/setup_zwave.sh b/aarch64/scripts/setup_zwave.sh new file mode 100644 index 0000000..ff1b82f --- /dev/null +++ b/aarch64/scripts/setup_zwave.sh @@ -0,0 +1,19 @@ +#!/bin/bash + +echo "Checking openzwave installation state..." + +if [ -f /usr/local/lib64 ] +then + echo "Openzwave is already installed..." +else + echo "Openzwave is NOT installed. Going to install it now..." + cd /opt + curl -s -L -O http://old.openzwave.com/downloads/openzwave-1.6.945.tar.gz + tar -xf openzwave-1.6.945.tar.gz && rm openzwave-1.6.945.tar.gz + cd openzwave-1.6.945 && make > /dev/null 2>&1 && make install > /dev/null 2>&1 + ldconfig /usr/local/lib64 + cd /opt/iobroker + # echo "Openzwave is now installed..." +fi + +exit 0 \ No newline at end of file diff --git a/Dockerfile b/amd64/Dockerfile similarity index 93% rename from Dockerfile rename to amd64/Dockerfile index 4ae4fe7..bc1b165 100644 --- a/Dockerfile +++ b/amd64/Dockerfile @@ -23,7 +23,7 @@ RUN apt-get update && apt-get upgrade -y && apt-get install -y \ wget \ && rm -rf /var/lib/apt/lists/* -# Install node8 +# Install node10 RUN curl -sL https://deb.nodesource.com/setup_10.x | bash \ && apt-get update && apt-get install -y \ nodejs \ @@ -41,6 +41,7 @@ WORKDIR /opt/scripts/ COPY scripts/iobroker_startup.sh iobroker_startup.sh COPY scripts/setup_avahi.sh setup_avahi.sh COPY scripts/setup_packages.sh setup_packages.sh +COPY scripts/setup_zwave.sh setup_zwave.sh RUN chmod +x iobroker_startup.sh \ && chmod +x setup_avahi.sh \ && chmod +x setup_packages.sh @@ -70,9 +71,10 @@ ENV DEBIAN_FRONTEND="teletype" \ LC_ALL="de_DE.UTF-8" \ TZ="Europe/Berlin" \ PACKAGES="nano" \ - AVAHI="false" \ - SETUID=1000 \ - SETGID=1000 + AVAHI="false" \ + SETUID=1000 \ + SETGID=1000 \ + ZWAVE="false" # Setting up EXPOSE for Admin EXPOSE 8081/tcp diff --git a/amd64/scripts/iobroker_startup.sh b/amd64/scripts/iobroker_startup.sh new file mode 100644 index 0000000..68e9537 --- /dev/null +++ b/amd64/scripts/iobroker_startup.sh @@ -0,0 +1,176 @@ +#!/bin/bash + +# Reading ENV +packages=$PACKAGES +avahi=$AVAHI +uid=$SETUID +gid=$SETGID +zwave=$ZWAVE + +# Getting date and time for logging +dati=`date '+%Y-%m-%d %H:%M:%S'` + +# Header +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo -n "$(printf -- '-%.0s' {1..15})" && echo -n " "$dati" " && echo "$(printf -- '-%.0s' {1..15})" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Welcome to your ioBroker-container! -----" +echo "----- Startupscript is now running. -----" +echo "----- Please be patient! -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Debugging information -----" +echo "----- -----" +echo "----- System -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" arch: $(uname -m))" && echo " -----" +echo "----- -----" +echo "----- Versions -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" image: $VERSION)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" node: $(node -v))" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" npm: $(npm -v))" && echo " -----" +echo "----- -----" +echo "----- ENV -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" AVAHI: $AVAHI)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" PACKAGES: $PACKAGES)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" SETGID: $SETGID)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" SETUID: $SETUID)" && echo " -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +# Checking and installing additional packages +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 1 of 5: Installing additional packages -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +if [ "$packages" != "" ] +then + echo "The following packages will be installed:" $packages"..." + echo $packages > /opt/scripts/.packages + sh /opt/scripts/setup_packages.sh > /opt/scripts/setup_packages.log 2>&1 + echo "Done." +else + echo "There are no additional packages defined." +fi +echo ' ' + +# Change directory for next steps +cd /opt/iobroker + +# Detecting ioBroker-Installation +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 2 of 5: Detecting ioBroker installation -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +if [ `ls -1a|wc -l` -lt 3 ] +then + echo "There is no data detected in /opt/iobroker. Restoring..." + tar -xf /opt/initial_iobroker.tar -C / + echo "Done." +else + if [ -f /opt/iobroker/iobroker ] + then + echo "Installation of ioBroker detected in /opt/iobroker." + else + echo "There is data detected in /opt/iobroker, but it looks like it is no instance of iobroker!" + echo "Please check/ recreate mounted folder/ volume and restart ioBroker container." + exit 1 + fi +fi +echo ' ' + +# Checking ioBroker-Installation +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 3 of 5: Checking ioBroker installation -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +# Checking for first run and set uid/gid +if [ -f /opt/.firstrun ] +then + echo "This is the first run of a new container. Time for some preparation." + echo ' ' + echo "Changing UID to "$uid" and GID to "$gid"..." + usermod -u $uid iobroker + groupmod -g $gid iobroker + rm -f /opt/.firstrun + echo "Done." +else + echo "This is NOT the first run of the container. Some Steps will be skipped." +fi +echo ' ' + +# (Re)Setting permissions to "/opt/iobroker" and "/opt/scripts" +echo "(Re)Setting folder permissions (This might take a while! Please be patient!)..." + chown -R $uid:$gid /opt/iobroker + chown -R $uid:$gid /opt/scripts +echo "Done." +echo ' ' + +# Backing up original iobroker-file and changing sudo to gosu +echo "Fixing \"sudo-bug\" by replacing sudo with gosu..." + cp -a /opt/iobroker/iobroker /opt/iobroker/iobroker.bak + chmod 755 /opt/iobroker/iobroker + sed -i 's/sudo -H -u/gosu/g' /opt/iobroker/iobroker +echo "Done." +echo ' ' + +# Checking for first run of a new installation and renaming ioBroker +if [ -f /opt/iobroker/.install_host ] +then + echo "Looks like this is a new and empty installation of ioBroker." + echo "Hostname needs to be updated to " $(hostname)"..." + sh /opt/iobroker/iobroker host $(cat /opt/iobroker/.install_host) + rm -f /opt/iobroker/.install_host + echo 'Done.' + echo ' ' +fi + +# Setting up prerequisites for some ioBroker-adapters +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 4 of 5: Applying special settings -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +echo "Some adapters have special requirements which can be activated by the use of environment variables." +echo "For more information take a look at readme.md" +echo ' ' + +# Checking for and setting up avahi-daemon +if [ "$avahi" = "true" ] +then + echo "Avahi-daemon is activated by ENV." + chmod 764 /opt/scripts/setup_avahi.sh + sh /opt/scripts/setup_avahi.sh + echo "Done." + echo ' ' +fi + +if [ "$zwave" = "true" ] +then + echo "ZWave is activated by ENV." + chmod 764 /opt/scripts/setup_zwave.sh + sh /opt/scripts/setup_zwave.sh + echo "Done." + echo ' ' +fi + +sleep 5 + +# Starting ioBroker +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 5 of 5: ioBroker startup -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "Starting ioBroker..." +echo ' ' +#gosu iobroker node --trace-warnings node_modules/iobroker.js-controller/controller.js > /opt/iobroker/iobroker.log 2>&1 & +gosu iobroker node node_modules/iobroker.js-controller/controller.js + +# Preventing container restart by keeping a process alive even if iobroker will be stopped +tail -f /dev/null diff --git a/amd64/scripts/setup_avahi.sh b/amd64/scripts/setup_avahi.sh new file mode 100644 index 0000000..2f64a72 --- /dev/null +++ b/amd64/scripts/setup_avahi.sh @@ -0,0 +1,35 @@ +#!/bin/bash + +echo "Checking avahi-daemon installation state..." + +if [ -f /usr/sbin/avahi-daemon ] +then + echo "Avahi is already installed..." +else + echo "Avahi-daemon is NOT installed. Going to install it now..." + apt-get update > /opt/scripts/avahi_startup.log 2>&1 + apt-get install -y libavahi-compat-libdnssd-dev avahi-daemon >> /opt/scripts/avahi_startup.log 2>&1 + rm -rf /var/lib/apt/lists/* >> /opt/scripts/avahi_startup.log 2>&1 + echo "Configuring avahi-daemon..." + sed -i '/^rlimit-nproc/s/^\(.*\)/#\1/g' /etc/avahi/avahi-daemon.conf + echo "Configuring dbus..." + mkdir /var/run/dbus/ +fi + +if [ -f /var/run/dbus/pid ]; +then + rm -f /var/run/dbus/pid +fi + +if [ -f /var/run/avahi-daemon//pid ]; +then + rm -f /var/run/avahi-daemon//pid +fi + +echo "Starting dbus..." +dbus-daemon --system + +echo "Starting avahi-daemon..." +/etc/init.d/avahi-daemon start + +exit 0 diff --git a/amd64/scripts/setup_packages.sh b/amd64/scripts/setup_packages.sh new file mode 100644 index 0000000..8dc6848 --- /dev/null +++ b/amd64/scripts/setup_packages.sh @@ -0,0 +1,8 @@ +#!/bin/bash + +apt-get update +apt-get install -y $(cat /opt/scripts/.packages) +rm -rf /var/lib/apt/lists/* +rm -f /opt/scripts/.packages + +exit 0 diff --git a/amd64/scripts/setup_zwave.sh b/amd64/scripts/setup_zwave.sh new file mode 100644 index 0000000..ff1b82f --- /dev/null +++ b/amd64/scripts/setup_zwave.sh @@ -0,0 +1,19 @@ +#!/bin/bash + +echo "Checking openzwave installation state..." + +if [ -f /usr/local/lib64 ] +then + echo "Openzwave is already installed..." +else + echo "Openzwave is NOT installed. Going to install it now..." + cd /opt + curl -s -L -O http://old.openzwave.com/downloads/openzwave-1.6.945.tar.gz + tar -xf openzwave-1.6.945.tar.gz && rm openzwave-1.6.945.tar.gz + cd openzwave-1.6.945 && make > /dev/null 2>&1 && make install > /dev/null 2>&1 + ldconfig /usr/local/lib64 + cd /opt/iobroker + # echo "Openzwave is now installed..." +fi + +exit 0 \ No newline at end of file diff --git a/armv7hf/Dockerfile b/armv7hf/Dockerfile new file mode 100644 index 0000000..293db80 --- /dev/null +++ b/armv7hf/Dockerfile @@ -0,0 +1,84 @@ +FROM balenalib/armv7hf-debian:stretch + +MAINTAINER Andre Germann + +ENV DEBIAN_FRONTEND noninteractive + +# Install prerequisites +RUN apt-get update && apt-get upgrade -y && apt-get install -y \ + acl \ + apt-utils \ + build-essential \ + curl \ + git \ + gnupg2 \ + libcap2-bin \ + libpam0g-dev \ + libudev-dev \ + locales \ + procps \ + python \ + gosu \ + unzip \ + wget \ + && rm -rf /var/lib/apt/lists/* + +# Install node8 +RUN curl -sL https://deb.nodesource.com/setup_10.x | bash \ + && apt-get update && apt-get install -y \ + nodejs \ + && rm -rf /var/lib/apt/lists/* + +# Generating locales +RUN sed -i 's/^# *\(de_DE.UTF-8\)/\1/' /etc/locale.gen \ + && sed -i 's/^# *\(en_US.UTF-8\)/\1/' /etc/locale.gen \ + && locale-gen + +# Create scripts directory and copy scripts +RUN mkdir -p /opt/scripts/ \ + && chmod 777 /opt/scripts/ +WORKDIR /opt/scripts/ +COPY scripts/iobroker_startup.sh iobroker_startup.sh +COPY scripts/setup_avahi.sh setup_avahi.sh +COPY scripts/setup_packages.sh setup_packages.sh +COPY scripts/setup_zwave.sh setup_zwave.sh +RUN chmod +x iobroker_startup.sh \ + && chmod +x setup_avahi.sh \ + && chmod +x setup_packages.sh + +# Install ioBroker +WORKDIR / +RUN apt-get update \ + && curl -sL https://raw.githubusercontent.com/ioBroker/ioBroker/stable-installer/installer.sh | bash - \ + && echo $(hostname) > /opt/iobroker/.install_host \ + && echo $(hostname) > /opt/.firstrun \ + && rm -rf /var/lib/apt/lists/* + +# Install node-gyp +WORKDIR /opt/iobroker/ +RUN npm config set unsafe-perm true # To fix "Error: could not get uid/gid" +RUN npm install -g node-gyp + +# Backup initial ioBroker-folder +RUN tar -cf /opt/initial_iobroker.tar /opt/iobroker + +# Setting up iobroker-user +RUN chsh -s /bin/bash iobroker + +# Setting up ENVs +ENV DEBIAN_FRONTEND="teletype" \ + LANG="de_DE.UTF-8" \ + LANGUAGE="de_DE:de" \ + LC_ALL="de_DE.UTF-8" \ + TZ="Europe/Berlin" \ + PACKAGES="nano" \ + AVAHI="false" \ + SETUID=1000 \ + SETGID=1000 \ + ZWAVE="false" + +# Setting up EXPOSE for Admin +EXPOSE 8081/tcp + +# Run startup-script +ENTRYPOINT ["/opt/scripts/iobroker_startup.sh"] diff --git a/armv7hf/scripts/iobroker_startup.sh b/armv7hf/scripts/iobroker_startup.sh new file mode 100644 index 0000000..68e9537 --- /dev/null +++ b/armv7hf/scripts/iobroker_startup.sh @@ -0,0 +1,176 @@ +#!/bin/bash + +# Reading ENV +packages=$PACKAGES +avahi=$AVAHI +uid=$SETUID +gid=$SETGID +zwave=$ZWAVE + +# Getting date and time for logging +dati=`date '+%Y-%m-%d %H:%M:%S'` + +# Header +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo -n "$(printf -- '-%.0s' {1..15})" && echo -n " "$dati" " && echo "$(printf -- '-%.0s' {1..15})" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Welcome to your ioBroker-container! -----" +echo "----- Startupscript is now running. -----" +echo "----- Please be patient! -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Debugging information -----" +echo "----- -----" +echo "----- System -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" arch: $(uname -m))" && echo " -----" +echo "----- -----" +echo "----- Versions -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" image: $VERSION)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" node: $(node -v))" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" npm: $(npm -v))" && echo " -----" +echo "----- -----" +echo "----- ENV -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" AVAHI: $AVAHI)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" PACKAGES: $PACKAGES)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" SETGID: $SETGID)" && echo " -----" +echo -n "----- " && echo -n "$(printf "%-10s %-23s" SETUID: $SETUID)" && echo " -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +# Checking and installing additional packages +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 1 of 5: Installing additional packages -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +if [ "$packages" != "" ] +then + echo "The following packages will be installed:" $packages"..." + echo $packages > /opt/scripts/.packages + sh /opt/scripts/setup_packages.sh > /opt/scripts/setup_packages.log 2>&1 + echo "Done." +else + echo "There are no additional packages defined." +fi +echo ' ' + +# Change directory for next steps +cd /opt/iobroker + +# Detecting ioBroker-Installation +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 2 of 5: Detecting ioBroker installation -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +if [ `ls -1a|wc -l` -lt 3 ] +then + echo "There is no data detected in /opt/iobroker. Restoring..." + tar -xf /opt/initial_iobroker.tar -C / + echo "Done." +else + if [ -f /opt/iobroker/iobroker ] + then + echo "Installation of ioBroker detected in /opt/iobroker." + else + echo "There is data detected in /opt/iobroker, but it looks like it is no instance of iobroker!" + echo "Please check/ recreate mounted folder/ volume and restart ioBroker container." + exit 1 + fi +fi +echo ' ' + +# Checking ioBroker-Installation +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 3 of 5: Checking ioBroker installation -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +# Checking for first run and set uid/gid +if [ -f /opt/.firstrun ] +then + echo "This is the first run of a new container. Time for some preparation." + echo ' ' + echo "Changing UID to "$uid" and GID to "$gid"..." + usermod -u $uid iobroker + groupmod -g $gid iobroker + rm -f /opt/.firstrun + echo "Done." +else + echo "This is NOT the first run of the container. Some Steps will be skipped." +fi +echo ' ' + +# (Re)Setting permissions to "/opt/iobroker" and "/opt/scripts" +echo "(Re)Setting folder permissions (This might take a while! Please be patient!)..." + chown -R $uid:$gid /opt/iobroker + chown -R $uid:$gid /opt/scripts +echo "Done." +echo ' ' + +# Backing up original iobroker-file and changing sudo to gosu +echo "Fixing \"sudo-bug\" by replacing sudo with gosu..." + cp -a /opt/iobroker/iobroker /opt/iobroker/iobroker.bak + chmod 755 /opt/iobroker/iobroker + sed -i 's/sudo -H -u/gosu/g' /opt/iobroker/iobroker +echo "Done." +echo ' ' + +# Checking for first run of a new installation and renaming ioBroker +if [ -f /opt/iobroker/.install_host ] +then + echo "Looks like this is a new and empty installation of ioBroker." + echo "Hostname needs to be updated to " $(hostname)"..." + sh /opt/iobroker/iobroker host $(cat /opt/iobroker/.install_host) + rm -f /opt/iobroker/.install_host + echo 'Done.' + echo ' ' +fi + +# Setting up prerequisites for some ioBroker-adapters +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 4 of 5: Applying special settings -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' + +echo "Some adapters have special requirements which can be activated by the use of environment variables." +echo "For more information take a look at readme.md" +echo ' ' + +# Checking for and setting up avahi-daemon +if [ "$avahi" = "true" ] +then + echo "Avahi-daemon is activated by ENV." + chmod 764 /opt/scripts/setup_avahi.sh + sh /opt/scripts/setup_avahi.sh + echo "Done." + echo ' ' +fi + +if [ "$zwave" = "true" ] +then + echo "ZWave is activated by ENV." + chmod 764 /opt/scripts/setup_zwave.sh + sh /opt/scripts/setup_zwave.sh + echo "Done." + echo ' ' +fi + +sleep 5 + +# Starting ioBroker +echo "$(printf -- '-%.0s' {1..60})" +echo "----- Step 5 of 5: ioBroker startup -----" +echo "$(printf -- '-%.0s' {1..60})" +echo ' ' +echo "Starting ioBroker..." +echo ' ' +#gosu iobroker node --trace-warnings node_modules/iobroker.js-controller/controller.js > /opt/iobroker/iobroker.log 2>&1 & +gosu iobroker node node_modules/iobroker.js-controller/controller.js + +# Preventing container restart by keeping a process alive even if iobroker will be stopped +tail -f /dev/null diff --git a/armv7hf/scripts/setup_avahi.sh b/armv7hf/scripts/setup_avahi.sh new file mode 100644 index 0000000..2f64a72 --- /dev/null +++ b/armv7hf/scripts/setup_avahi.sh @@ -0,0 +1,35 @@ +#!/bin/bash + +echo "Checking avahi-daemon installation state..." + +if [ -f /usr/sbin/avahi-daemon ] +then + echo "Avahi is already installed..." +else + echo "Avahi-daemon is NOT installed. Going to install it now..." + apt-get update > /opt/scripts/avahi_startup.log 2>&1 + apt-get install -y libavahi-compat-libdnssd-dev avahi-daemon >> /opt/scripts/avahi_startup.log 2>&1 + rm -rf /var/lib/apt/lists/* >> /opt/scripts/avahi_startup.log 2>&1 + echo "Configuring avahi-daemon..." + sed -i '/^rlimit-nproc/s/^\(.*\)/#\1/g' /etc/avahi/avahi-daemon.conf + echo "Configuring dbus..." + mkdir /var/run/dbus/ +fi + +if [ -f /var/run/dbus/pid ]; +then + rm -f /var/run/dbus/pid +fi + +if [ -f /var/run/avahi-daemon//pid ]; +then + rm -f /var/run/avahi-daemon//pid +fi + +echo "Starting dbus..." +dbus-daemon --system + +echo "Starting avahi-daemon..." +/etc/init.d/avahi-daemon start + +exit 0 diff --git a/armv7hf/scripts/setup_packages.sh b/armv7hf/scripts/setup_packages.sh new file mode 100644 index 0000000..8dc6848 --- /dev/null +++ b/armv7hf/scripts/setup_packages.sh @@ -0,0 +1,8 @@ +#!/bin/bash + +apt-get update +apt-get install -y $(cat /opt/scripts/.packages) +rm -rf /var/lib/apt/lists/* +rm -f /opt/scripts/.packages + +exit 0 diff --git a/armv7hf/scripts/setup_zwave.sh b/armv7hf/scripts/setup_zwave.sh new file mode 100644 index 0000000..ff1b82f --- /dev/null +++ b/armv7hf/scripts/setup_zwave.sh @@ -0,0 +1,19 @@ +#!/bin/bash + +echo "Checking openzwave installation state..." + +if [ -f /usr/local/lib64 ] +then + echo "Openzwave is already installed..." +else + echo "Openzwave is NOT installed. Going to install it now..." + cd /opt + curl -s -L -O http://old.openzwave.com/downloads/openzwave-1.6.945.tar.gz + tar -xf openzwave-1.6.945.tar.gz && rm openzwave-1.6.945.tar.gz + cd openzwave-1.6.945 && make > /dev/null 2>&1 && make install > /dev/null 2>&1 + ldconfig /usr/local/lib64 + cd /opt/iobroker + # echo "Openzwave is now installed..." +fi + +exit 0 \ No newline at end of file diff --git a/manifest.yml b/manifest.yml new file mode 100644 index 0000000..ae9fa3b --- /dev/null +++ b/manifest.yml @@ -0,0 +1,19 @@ +image: buanet/iobroker:$DOCKERTAG +manifests: + - + image: buanet/iobroker:$VERSION-amd64 + platform: + architecture: amd64 + os: linux + - + image: buanet/iobroker:$VERSION-aarch64 + platform: + architecture: arm64 + variant: v8 + os: linux + - + image: buanet/iobroker:$VERSION-armv7hf + platform: + architecture: arm + variant: v7 + os: linux \ No newline at end of file diff --git a/maintenance_scripts/backup_iobroker_folder.sh b/opt/maintenance-scripts/backup_iobroker_folder.sh similarity index 100% rename from maintenance_scripts/backup_iobroker_folder.sh rename to opt/maintenance-scripts/backup_iobroker_folder.sh diff --git a/maintenance_scripts/iobroker_restart.sh b/opt/maintenance-scripts/iobroker_restart.sh similarity index 100% rename from maintenance_scripts/iobroker_restart.sh rename to opt/maintenance-scripts/iobroker_restart.sh diff --git a/maintenance_scripts/iobroker_stop.sh b/opt/maintenance-scripts/iobroker_stop.sh similarity index 100% rename from maintenance_scripts/iobroker_stop.sh rename to opt/maintenance-scripts/iobroker_stop.sh diff --git a/scripts/iobroker_startup.sh b/scripts/iobroker_startup.sh deleted file mode 100644 index 3c46dfb..0000000 --- a/scripts/iobroker_startup.sh +++ /dev/null @@ -1,103 +0,0 @@ -#!/bin/bash - -# Reading env-variables -packages=$PACKAGES -avahi=$AVAHI -uid=$SETUID -gid=$SETGID - -# Getting date and time for logging -dati=`date '+%Y-%m-%d %H:%M:%S'` - -# Information -echo '' -echo '----------------------------------------' -echo '----- Image-Version: 3.1.2beta -----' -echo '----- '$dati' -----' -echo '----------------------------------------' -echo '' -echo 'Startupscript running...' - -# Checking and installing additional packages -if [ "$packages" != "" ] -then - echo '' - echo 'Installing additional packages...' - echo 'The following packages will be installed:' $packages - echo $packages > /opt/scripts/.packages - sh /opt/scripts/setup_packages.sh > /opt/scripts/setup_packages.log 2>&1 - echo 'Done.' -fi - -cd /opt/iobroker - -# Checking and restoring ioBroker to empty mounted folder -if [ `ls -1a|wc -l` -lt 3 ] -then - echo '' - echo 'Directory /opt/iobroker is empty!' - echo 'Restoring data from image...' - tar -xf /opt/initial_iobroker.tar -C / - echo 'Done.' -fi - -# Checking for first run and set uid/gid and permissions -if [ -f /opt/.firstrun ] -then - echo '' - echo 'Changing UID/GID and permissions upon first run...' - echo 'Setting UID to '$uid' and GID to '$gid'...' - usermod -u $uid iobroker - groupmod -g $gid iobroker - echo 'Done.' - echo 'Setting folder permissions (This might take a while! Please be patient!)...' - chown -R $uid:$gid /opt/iobroker - chown -R $uid:$gid /opt/scripts - rm -f /opt/.firstrun - echo 'Done.' -fi - -# Backing up original iobroker-file and changing sudo to gosu -cp -a /opt/iobroker/iobroker /opt/iobroker/iobroker.bak -chmod 755 /opt/iobroker/iobroker -sed -i 's/sudo -H -u/gosu/g' /opt/iobroker/iobroker - -# Checking for first run of a new installation and renaming ioBroker -if [ -f /opt/iobroker/.install_host ] -then - echo '' - echo 'This is the first run of an new installation...' - echo 'Hostname given is' $(hostname)'...' - echo 'Renaming ioBroker...' - sh /opt/iobroker/iobroker host $(cat /opt/iobroker/.install_host) - rm -f /opt/iobroker/.install_host - echo 'Done.' -fi - -# Checking for and setting up avahi-daemon -if [ "$avahi" = "true" ] -then - echo '' - echo 'Initializing Avahi-Daemon...' - chmod 764 /opt/scripts/setup_avahi.sh - sh /opt/scripts/setup_avahi.sh - echo 'Done.' -fi - -sleep 5 - -# Starting ioBroker -echo '' -echo 'Starting ioBroker...' -echo '' -echo '----------------------------------------' -echo '------- ioBroker Logging -------' -echo '----------------------------------------' -echo '' - -#touch /opt/iobroker/iobroker.log -#gosu iobroker node --trace-warnings node_modules/iobroker.js-controller/controller.js > /opt/iobroker/iobroker.log 2>&1 & -gosu iobroker node node_modules/iobroker.js-controller/controller.js - -# Preventing container restart by keeping a process alive even if iobroker will be stopped -tail -f /dev/null