summaryrefslogtreecommitdiffstats
path: root/scripts/sh/_templates/goapps
diff options
context:
space:
mode:
authorGeorg2022-01-02 06:36:45 +0100
committerGeorg2022-01-02 06:36:45 +0100
commit935b8c642f8aaed31bca17faccaedf0e57ba9efd (patch)
treedeb1d2bdd53aef299f59fb1aebc459884fc264f3 /scripts/sh/_templates/goapps
parent134560a32d52329a59906de5392e69df9608368c (diff)
parentdc8f806686172d490ae50ac0f9f5d2cdc887d61b (diff)
downloadsystem-935b8c642f8aaed31bca17faccaedf0e57ba9efd.tar.gz
system-935b8c642f8aaed31bca17faccaedf0e57ba9efd.tar.bz2
system-935b8c642f8aaed31bca17faccaedf0e57ba9efd.zip
Merge branch 'master' of ssh://git.com.de:28/LibertaCasa/system
Diffstat (limited to 'scripts/sh/_templates/goapps')
-rw-r--r--scripts/sh/_templates/goapps/deploy_app.sh38
-rw-r--r--scripts/sh/_templates/goapps/remove_app.sh26
-rw-r--r--scripts/sh/_templates/goapps/update_app.sh26
3 files changed, 90 insertions, 0 deletions
diff --git a/scripts/sh/_templates/goapps/deploy_app.sh b/scripts/sh/_templates/goapps/deploy_app.sh
new file mode 100644
index 0000000..74762ad
--- /dev/null
+++ b/scripts/sh/_templates/goapps/deploy_app.sh
@@ -0,0 +1,38 @@
+#!/bin/sh
+DISTRIB=$(awk -F= '/^NAME/{print $2}' /etc/os-release)
+echo "Detected $DISTRIB"
+if [ ${DISTRIB} = "openSUSE Leap" ]
+echo
+then
+if [ ! -d /opt/app ]
+then
+echo "app not found. Preparing Install"
+
+# Distrib package manager installs deps
+zypper in --no-recommends -y git make
+REPO="<repo_url.git>"
+mkdir /opt/app
+useradd -rUd /opt/app -s /bin/false app
+chown app:app /opt/app
+chmod 750 /opt/app
+usermod -aG app pratyush
+usermod -aG app georg
+sudo -u app git clone $REPO /opt/app/app-git
+cd /opt/app/app-git || exit
+sudo -u app make build
+sudo -u app chmod +x app
+ln -s /opt/app/app-git/app /opt/app/app
+
+# Insert application specific commands here.
+
+# consider a change in directory structure based on applications?
+# update the statement below accordingly.
+sudo cp path/to/unitfile /etc/systemd/system/app.service
+sudo systemctl daemon-reload
+sudo systemctl enable --now app.service
+else
+echo "Existing app installation or leftovers detected. Consider remove_app.sh."
+fi
+else
+echo "This is currently only compatible with SUSE Leap nodes."
+fi \ No newline at end of file
diff --git a/scripts/sh/_templates/goapps/remove_app.sh b/scripts/sh/_templates/goapps/remove_app.sh
new file mode 100644
index 0000000..1def777
--- /dev/null
+++ b/scripts/sh/_templates/goapps/remove_app.sh
@@ -0,0 +1,26 @@
+#!/bin/sh
+
+# Check for existing installation in `/opt`.
+
+if [ ! -d /opt/app ]
+then
+echo "This will kill running app services and cause data loss! Remove app? "
+read text -r
+
+# https://github.com/koalaman/shellcheck/wiki/SC3015
+# https://github.com/koalaman/shellcheck/wiki/SC2003
+# Need a POSIX compatible regex soln below!
+expr "$text" : "^[Yy]$" > /dev/null
+if [ "$text" ]
+then
+echo "Removing app"
+systemctl disable --now app.service || true
+rm -f /etc/systemd/system/app.service
+rm -rf /opt/app
+userdel -f app
+groupdel -f app
+echo "OK"
+fi
+else
+echo "Could not find a compatible installation of app."
+fi
diff --git a/scripts/sh/_templates/goapps/update_app.sh b/scripts/sh/_templates/goapps/update_app.sh
new file mode 100644
index 0000000..bbc0b1e
--- /dev/null
+++ b/scripts/sh/_templates/goapps/update_app.sh
@@ -0,0 +1,26 @@
+#!/bin/sh
+
+# Only supports git source builds currently.
+
+if [ -f /opt/app/app-git/app ]
+then
+echo "This will immediately stop app if it is running. Update app on this system? "
+read text -r
+expr "$text" : "^[Yy]$" > /dev/null
+if [ "$text" ]
+then
+# Inconsistent `sudo` use?
+systemctl stop app.service
+
+# Update golang using `deploy_go`
+
+cd /opt/app/app-git || exit
+rm -f app
+git pull
+sudo -u app make build
+# insert misc commands as needed.
+systemctl start app.service
+fi
+else
+echo "app does not seem to be installed. Consider deploy_app.sh."
+fi \ No newline at end of file