pleroma/setup.sh

56 lines
1.5 KiB
Bash
Raw Normal View History

2022-05-04 11:57:40 -06:00
#!/bin/bash
export SHELL="/bin/bash"
FILE='/tmp/config/prod.secret.exs'
BACKUP_CONFIG='/config/prod.secret.exs'
PG_CHECK='/var/lib/postgresql/data/pg_hba.conf'
crontab /opt/crontab
#Postgres Setup
chown -R postgres:postgres /run/postgresql/
chown -R postgres:postgres /var/lib/postgresql
chown -R postgres:postgres /var/log/postgresql
if [ -f "$BACKUP_CONFIG" ]
then
echo;echo "Copying old config....";echo
cp -f /config/* /opt/pleroma/config/
fi
if [ ! -f "$PG_CHECK" ]
then
su postgres -s $SHELL -lc "/usr/lib/postgresql/14/bin/initdb --auth-host=trust -D /var/lib/postgresql/data"
echo "host all all 0.0.0.0/0 md5" >> /var/lib/postgresql/data/pg_hba.conf
fi
su postgres -s $SHELL -lc "/usr/lib/postgresql/14/bin/pg_ctl start -D /var/lib/postgresql/data"
cd /opt/pleroma
#Pleroma Configuration
if [ ! -f "$FILE" ]
then
MIX_ENV=prod mix pleroma.instance gen
mv config/generated_config.exs config/prod.secret.exs
cp -f config/* /config/
sudo -Hu postgres psql -f config/setup_db.psql
fi
mkdir -p /var/lib/pleroma/uploads
mkdir -p /var/lib/pleroma/static
#Nginx and SSL
sed -i "s/replaceME/${ENDPOINT}/g" /etc/nginx/conf.d/default.conf
openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 -subj "/C=US/ST=CO/L=Denver/O=$ENDPOINT/CN=$ENDPOINT" -keyout /etc/ssl/certs/nginx-selfsigned.key -out /etc/ssl/certs/nginx-selfsigned.crt
mkdir /var/run/nginx
#Database Migrations
MIX_ENV=prod mix ecto.migrate
touch /configured.txt
#Start Pleroma
MIX_ENV=prod mix phx.server