#!/bin/bash # # Federated Computer NextCloud Service PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin config_nextcloud() { echo -ne "\n* Configuring fstack/nextcloud container.." spin & SPINPID=$! if [ ! -d "fstack/nextcloud" ]; then mkdir -p fstack/nextcloud/data/root/certs &> /dev/null mkdir -p fstack/nextcloud/data/var/www/html &> /dev/null mkdir -p fstack/nextcloud/data/etc/apache2/sites-enabled &> /dev/null cp -rf fstack/dns/data/etc/letsencrypt/archive/$DOMAIN/*.pem fstack/nextcloud/data/root/certs/ fi DOMAIN_ARRAY=(${DOMAIN//./ }) DOMAIN_FIRST=${DOMAIN_ARRAY[0]} DOMAIN_LAST=${DOMAIN_ARRAY[1]} cat > fstack/nextcloud/docker-compose.yml < fstack/nextcloud/supervisord.conf < fstack/nextcloud/Dockerfile <> /etc/sudoers \ && useradd -m ansible -s /bin/bash \ && sudo -u ansible mkdir /home/ansible/.ssh \ && mkdir -p /var/run/sshd RUN apt-get install -y supervisor \ && rm -rf /var/lib/apt/lists/* \ && mkdir /var/log/supervisord /var/run/supervisord COPY supervisord.conf / ENV NEXTCLOUD_UPDATE=1 CMD ["/usr/bin/supervisord", "-c", "/supervisord.conf"] EOF cat > fstack/nextcloud/data/root/nextcloud.sh < fstack/nextcloud/data/etc/apache2/sites-enabled/000-default.conf <<'EOF' LoadModule ssl_module /usr/lib/apache2/modules/mod_ssl.so ServerAdmin admin@localhost DocumentRoot /var/www/html ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined SSLEngine on SSLCertificateFile /root/certs/fullchain1.pem SSLCertificateKeyFile /root/certs/privkey1.pem ServerAdmin admin@localhost DocumentRoot /var/www/html ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined EOF kill -9 $SPINPID &> /dev/null echo -ne "done." } start_nextcloud() { echo -ne "\n* Starting fstack/nextcloud service.." spin & SPINPID=$! if [ $DEBUG ]; then # Start fstack/nextcloud with output to console for debug docker-compose -f fstack/nextcloud/docker-compose.yml -p nextcloud up --build [ $? -eq 0 ] && echo -ne "done.\n" || fail "There was a problem starting service fstack/nextcloud" else docker-compose -f fstack/nextcloud/docker-compose.yml -p nextcloud up --build -d &> /dev/null # Keep trying nextcloud port 80 to make sure it's up # before we proceed RETRY="35" while [ $RETRY -gt 0 ]; do nc -z 172.99.0.15 80 &> /dev/null if [ $? -eq 0 ]; then break else if [ "$RETRY" == 1 ]; then docker-compose -f fstack/nextcloud/docker-compose.yml -p nextcloud down &> /dev/null kill -9 $SPINPID &> /dev/null fail "There was a problem starting service fstack/nextcloud\nCheck the output of 'docker logs nextcloud' or turn on\ndebug with -d" fi ((RETRY--)) sleep 7 fi done fi # Move nextcloud.sh and set nextcloud.sh executable docker exec -it nextcloud mv /root/nextcloud.sh /var/www/html/ docker exec -it nextcloud chown www-data:root /var/www/html/nextcloud.sh docker exec -it nextcloud chmod 755 /var/www/html/nextcloud.sh [ $? -ne 0 ] && fail "Couldn't chown nextcloud.sh in fstack/nextcloud container" # Run nextcloud.sh - Setup LDAP, configuration for nextcloud docker exec -it -u 33 nextcloud /var/www/html/nextcloud.sh &> /dev/null [ $? -ne 0 ] && fail "Couldn't run nextcloud.sh inside fstack/nextcloud container" # Enable SSL module in fstack/nextcloud docker exec -it nextcloud a2enmod ssl &> /dev/null [ $? -ne 0 ] && fail "Couldn't run a2enmod ssl in fstack/nextcloud container" docker exec -it nextcloud service apache2 restart &> /dev/null kill -9 $SPINPID &> /dev/null echo -ne "done." }