#!/bin/sh

#
# Parameters
#

interactive=true

if [ "$1" = "--no-interactive" ]; then
	interactive=false
fi

#
# Enable and start Postgres
#

sudo systemctl start postgresql.service
sudo systemctl enable postgresql.service

#
# Create databse and user
#

if [ "$interactive" = "true" ]; then
	sudo -u postgres -- createuser -P kemal
	sudo -u postgres -- createdb -O kemal invidious
else
	# Generate a DB password
	if [ -z "$POSTGRES_PASS" ]; then
		echo "Generating database password"
		POSTGRES_PASS=$(tr -dc 'A-Za-z0-9.;!?{[()]}\\/' < /dev/urandom | head -c16)
	fi

	# hostname:port:database:username:password
	echo "Writing .pgpass"
	echo "127.0.0.1:*:invidious:kemal:${POSTGRES_PASS}" > "$HOME/.pgpass"

	sudo -u postgres -- psql -c "CREATE USER kemal WITH PASSWORD '$POSTGRES_PASS';"
	sudo -u postgres -- psql -c "CREATE DATABASE invidious WITH OWNER kemal;"
	sudo -u postgres -- psql -c "GRANT ALL ON DATABASE invidious TO kemal;"
fi


#
# Instructions for modification of pg_hba.conf
#

if [ "$interactive" = "true" ]; then
	echo
	echo "-------------"
	echo "   NOTICE    "
	echo "-------------"
	echo
	echo "Make sure that your postgreSQL's pg_hba.conf file contains the follwong"
	echo "lines before previous 'host' configurations:"
	echo
	echo "host  invidious  kemal  127.0.0.1/32  md5"
	echo "host  invidious  kemal  ::1/128       md5"
	echo
fi