From f1901562e5d3859b4e9a9eb7c5f48c6db73fc8b1 Mon Sep 17 00:00:00 2001
From: Christian Heller <c.heller@plomlompom.de>
Date: Fri, 28 Feb 2020 00:32:36 +0100
Subject: [PATCH] Extend Pleroma-from-source scripting.

---
 buster/setup_scripts/migrate_app.sh          |  9 ++++++---
 buster/setup_scripts/restore_app.sh          | 11 ++++++++---
 buster/setup_scripts/setup_pleroma_source.sh |  6 +++++-
 3 files changed, 19 insertions(+), 7 deletions(-)

diff --git a/buster/setup_scripts/migrate_app.sh b/buster/setup_scripts/migrate_app.sh
index cda12f5..6e18f33 100755
--- a/buster/setup_scripts/migrate_app.sh
+++ b/buster/setup_scripts/migrate_app.sh
@@ -6,15 +6,18 @@ if [ "$#" -lt 2 ]; then
     echo 'Need two arguments: old server IP, and service name.'
     false
 fi
-if [ ! "$2" = "pleroma" ] && [ ! "$2" = "peertube" ]; then
-    echo "Need legal service name (pleroma or peertube)."
+if [ ! "$2" = "pleroma_otp" ] && [ ! "$2" = "pleroma_source" ] && [ ! "$2" = "peertube" ]; then
+    echo "Need legal service name (pleroma_otp or pleroma_source or peertube)."
     false
 fi
 server_ip="$1"
 app="$2"
-if [ "${app}" = "pleroma" ]; then
+if [ "${app}" = "pleroma_otp" ]; then
     db_name="pleroma"
     dirs="/var/lib/pleroma/uploads /etc/pleroma"
+if [ "${app}" = "pleroma_source" ]; then
+    db_name="pleroma"
+    dirs="/var/lib/pleroma/uploads /opt/pleroma/config"
 elif [ "${app}" = "peertube" ]; then
     db_name="peertube_prod"
     dirs="/var/www/peertube/storage /var/www/peertube/config"
diff --git a/buster/setup_scripts/restore_app.sh b/buster/setup_scripts/restore_app.sh
index dd1d856..363a5f6 100755
--- a/buster/setup_scripts/restore_app.sh
+++ b/buster/setup_scripts/restore_app.sh
@@ -6,8 +6,8 @@ if [ "$#" -lt 2 ]; then
     echo 'Need two arguments: service name and DB name.'
     false
 fi
-if [ ! "$1" = "pleroma" ] && [ ! "$1" = "peertube" ]; then
-    echo "Need legal service name (pleroma or peertube)."
+if [ ! "$1" = "pleroma_otp" ] && [ ! "$1" = "pleroma_sourc" ] && [ ! "$1" = "peertube" ]; then
+    echo "Need legal service name (pleroma_otp or pleroma_source or peertube)."
     false
 fi
 app="$1"
@@ -24,6 +24,11 @@ rm "${app}_backup/${db_name}.pgdump"
 
 cd "${app}_backup"
 for path in $(find . -type f); do
+    if [ "${app}" = "pleroma_source" ]; then
+        if [ "${path}" = '/opt/pleroma/config/prod.secret.exs' ]; then
+            continue  # skip file that contains passwords
+        fi
+    fi
     target_path=$(echo "${path}" | cut -c2-)
     source_path=$(realpath "${path}")
     dir=$(dirname "${target_path}")
@@ -32,7 +37,7 @@ for path in $(find . -type f); do
 done
 
 # TODO: Horrible hack, improve.
-if [ "${app}" = "pleroma" ]; then
+if [ "${app}" = "pleroma_otp" ]; then
     db_pw=$(cat /etc/pleroma/config.exs | grep password | sed 's/[ ]*password\: *//g' | sed 's/,//g' | sed 's/"//g')
 elif [ "${app}" = "peertube" ]; then
     db_pw=$(cat /var/www/peertube/config/production.yaml | grep password | head -1 | sed "s/[ ]*password\: *//g" | sed "s/'//g")
diff --git a/buster/setup_scripts/setup_pleroma_source.sh b/buster/setup_scripts/setup_pleroma_source.sh
index 614a7ed..e60350f 100755
--- a/buster/setup_scripts/setup_pleroma_source.sh
+++ b/buster/setup_scripts/setup_pleroma_source.sh
@@ -58,7 +58,11 @@ mv config/{generated_config.exs,prod.secret.exs}"
 su postgres -s $SHELL -lc 'psql -f /tmp/setup_db.psql'
 su pleroma -s $SHELL -lc 'cd /opt/pleroma && MIX_ENV=prod mix ecto.migrate'
 
-# TODO: config customization, prod.secret.exs
+# Add our own plom.exs and import it to prod.secret.exs
+echo '' >> /opt/pleroma/config/prod.secret.exs
+echo 'import_config "plom.exs"' >> /opt/pleroma/config/prod.secret.exs
+echo 'import Config' > /opt/pleroma/config/plom.exs
+cat "${config_tree_prefix}/other_files/append_pleroma_config" >> /opt/pleroma/config/plom.exs
 
 # Single-pixel picture hack for removing Pleroma FE images.
 cp "${config_tree_prefix}/other_files/pixel.png" /var/lib/pleroma/static/
-- 
2.30.2