Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/nextcloudpi.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornachoparker <nacho@ownyourbits.com>2017-05-20 16:10:09 +0300
committernachoparker <nacho@ownyourbits.com>2017-05-22 19:55:45 +0300
commit1df92f9eef9bea0935147c3e782c1fd63c1aa37f (patch)
tree5022290b84bb2f8a41dd68889374111c520d68b1 /nextcloudpi.sh
parentaddd0a8bec9dde406fa80075226a374e7b0ba868 (diff)
split building steps
Diffstat (limited to 'nextcloudpi.sh')
-rw-r--r--nextcloudpi.sh150
1 files changed, 150 insertions, 0 deletions
diff --git a/nextcloudpi.sh b/nextcloudpi.sh
new file mode 100644
index 00000000..1d364120
--- /dev/null
+++ b/nextcloudpi.sh
@@ -0,0 +1,150 @@
+#!/bin/bash
+
+# NextcloudPi additions to Raspbian
+# Tested with 2017-03-02-raspbian-jessie-lite.img
+#
+# Copyleft 2017 by Ignacio Nunez Hernanz <nacho _a_t_ ownyourbits _d_o_t_ com>
+# GPL licensed (see end of file) * Use at your own risk!
+#
+# Usage:
+#
+# ./installer.sh nextcloudpi.sh <IP> (<img>)
+#
+# See installer.sh instructions for details
+#
+# More at https://ownyourbits.com/2017/02/13/nextcloud-ready-raspberry-pi-image/
+#
+
+DBADMIN_=ncadmin
+DBPASSWD_=ownyourbits
+OPCACHEDIR=/var/www/nextcloud/data/.opcache
+CONFDIR=/usr/local/etc/nextcloudpi-config.d/
+APTINSTALL="apt-get install -y --no-install-recommends"
+
+
+install()
+{
+
+ # NEXTCLOUDPI-CONFIG
+ ##########################################
+ apt-get update
+ $APTINSTALL dialog
+ mkdir -p $CONFDIR
+ sed -i '/Change User Password/i"0 NextCloudPi Configuration" "Configuration of NextCloudPi" \\\\' /usr/bin/raspi-config
+ sed -i '/1\\\\ \*) do_change_pass ;;/i0\\\\ *) nextcloudpi-config ;;' /usr/bin/raspi-config
+
+ # NEXTCLOUDPI MOTD
+ ##########################################
+ mkdir /etc/update-motd.d
+ rm /etc/motd
+ ln -s /var/run/motd /etc/motd
+
+cat > /etc/update-motd.d/10logo <<EOF
+#!/bin/sh
+echo
+cat /usr/local/etc/ncp-ascii.txt
+EOF
+
+ cat > /etc/update-motd.d/20updates <<'EOF'
+#!/bin/bash
+/usr/local/bin/ncp-check-updates
+EOF
+ chmod a+x /etc/update-motd.d/*
+
+ # NEXTCLOUDPI AUTO TRUSTED DOMAIN
+ ##########################################
+ mkdir -p /usr/lib/systemd/system
+ cat > /usr/lib/systemd/system/nextcloud-domain.service <<'EOF'
+[Unit]
+Description=Register Current IP as Nextcloud trusted domain
+Requires=network.target
+After=mysql.service
+
+[Service]
+ExecStart=/bin/bash /usr/local/bin/nextcloud-domain.sh
+
+[Install]
+WantedBy=multi-user.target
+EOF
+
+ cat > /usr/local/bin/nextcloud-domain.sh <<'EOF'
+#!/bin/bash
+IFACE=$( ip r | grep "default via" | awk '{ print $5 }' )
+IP=$( ip a | grep "global $IFACE" | grep -oP '\d{1,3}(.\d{1,3}){3}' | head -1 )
+cd /var/www/nextcloud
+sudo -u www-data php occ config:system:set trusted_domains 1 --value=$IP
+EOF
+ systemctl enable nextcloud-domain
+
+ # NEXTCLOUDPI UPDATES
+ ##########################################
+ $APTINSTALL git
+
+ cat > /etc/cron.daily/ncp-check-version <<EOF
+#!/bin/sh
+/usr/local/bin/ncp-check-version
+EOF
+ chmod a+x /etc/cron.daily/ncp-check-version
+
+
+cat > /usr/local/bin/ncp-update <<'EOF'
+#!/bin/bash
+{
+[ $(id -u) -ne 0 ] && { printf "Must be run as root. Try 'sudo $0'\n"; exit 1; }
+ping -W 2 -w 1 -q github.com &>/dev/null || { echo "No internet connectivity"; exit 1; }
+echo -e "Downloading updates"
+rm -rf /tmp/ncp-update-tmp
+git clone -q --depth 1 https://github.com/nachoparker/nextcloud-raspbian-generator.git /tmp/ncp-update-tmp || exit 1
+cd /tmp/ncp-update-tmp
+
+echo -e "Performing updates"
+./update.sh
+
+VER=$( git describe --always --tags )
+echo $VER > /usr/local/etc/ncp-version
+echo $VER > /var/run/.ncp-latest-version
+
+cd /
+rm -rf /tmp/ncp-update-tmp
+
+echo -e "NextCloudPi updated to version \e[1m$VER\e[0m"
+exit
+}
+EOF
+ chmod a+x /usr/local/bin/ncp-update
+
+ # update to latest version from github as part of the build process
+ /usr/local/bin/ncp-update
+}
+
+configure() { :; }
+
+cleanup()
+{
+ [ "$STATE" != "1" ] && return
+ apt-get autoremove
+ apt-get clean
+ rm /var/lib/apt/lists/* -r
+ rm -f /home/pi/.bash_history
+
+ systemctl disable ssh
+ nohup halt &>/dev/null &
+}
+
+# License
+#
+# This script is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This script is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this script; if not, write to the
+# Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+# Boston, MA 02111-1307 USA
+