2020-07-10 18:15:41 +00:00
|
|
|
#!/bin/bash
|
|
|
|
set -e
|
2020-02-06 02:15:28 +00:00
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
# Default configurations
|
2020-02-06 02:15:28 +00:00
|
|
|
username=lemmy
|
|
|
|
dbname=lemmy
|
|
|
|
port=5432
|
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
yes_no_prompt_invalid() {
|
|
|
|
echo "Invalid input. Please enter either \"y\" or \"n\"." 1>&2
|
|
|
|
}
|
2020-02-06 21:07:34 +00:00
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
print_config() {
|
|
|
|
echo " database name: $dbname"
|
|
|
|
echo " username: $username"
|
|
|
|
echo " port: $port"
|
|
|
|
}
|
2020-02-06 21:07:34 +00:00
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
ask_for_db_config() {
|
|
|
|
echo "The default database configuration is:"
|
|
|
|
print_config
|
2020-02-06 21:07:34 +00:00
|
|
|
echo
|
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
default_config_final=0
|
|
|
|
default_config_valid=0
|
|
|
|
while [ "$default_config_valid" == 0 ]
|
|
|
|
do
|
|
|
|
read -p "Use this configuration (y/n)? " default_config
|
|
|
|
case "$default_config" in
|
|
|
|
[yY]* ) default_config_valid=1; default_config_final=1;;
|
|
|
|
[nN]* ) default_config_valid=1; default_config_final=0;;
|
|
|
|
* ) yes_no_prompt_invalid;;
|
|
|
|
esac
|
2020-02-06 21:07:34 +00:00
|
|
|
echo
|
2020-05-11 17:16:08 +00:00
|
|
|
done
|
|
|
|
|
|
|
|
if [ "$default_config_final" == 0 ]
|
2020-02-06 21:07:34 +00:00
|
|
|
then
|
2020-05-11 17:16:08 +00:00
|
|
|
config_ok_final=0
|
|
|
|
while [ "$config_ok_final" == 0 ]
|
|
|
|
do
|
|
|
|
read -p "Database name: " dbname
|
|
|
|
read -p "Username: " username
|
|
|
|
read -p "Port: " port
|
|
|
|
#echo
|
|
|
|
|
|
|
|
#echo "The database configuration is:"
|
|
|
|
#print_config
|
|
|
|
#echo
|
|
|
|
|
|
|
|
config_ok_valid=0
|
|
|
|
while [ "$config_ok_valid" == 0 ]
|
|
|
|
do
|
|
|
|
read -p "Use this configuration (y/n)? " config_ok
|
|
|
|
case "$config_ok" in
|
|
|
|
[yY]* ) config_ok_valid=1; config_ok_final=1;;
|
|
|
|
[nN]* ) config_ok_valid=1; config_ok_final=0;;
|
|
|
|
* ) yes_no_prompt_invalid;;
|
|
|
|
esac
|
|
|
|
echo
|
|
|
|
done
|
|
|
|
done
|
2020-02-06 21:07:34 +00:00
|
|
|
fi
|
2020-05-11 17:16:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ask_for_password() {
|
|
|
|
password=""
|
|
|
|
password_confirm=""
|
|
|
|
password_valid=0
|
|
|
|
while [ "$password_valid" == 0 ]
|
|
|
|
do
|
|
|
|
read -p "Enter database password: " -s password
|
|
|
|
echo
|
|
|
|
|
|
|
|
read -p "Verify database password: " -s password_confirm
|
|
|
|
echo
|
|
|
|
echo
|
2020-02-06 21:07:34 +00:00
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
# Start the loop from the top if either check fails
|
|
|
|
if [ -z "$password" ]
|
|
|
|
then
|
|
|
|
echo "Error: Password cannot be empty." 1>&2
|
|
|
|
echo
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
if [ "$password" != "$password_confirm" ]
|
|
|
|
then
|
|
|
|
echo "Error: Passwords don't match." 1>&2
|
|
|
|
echo
|
|
|
|
continue
|
|
|
|
fi
|
2020-02-06 21:07:34 +00:00
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
# Set the password_valid variable to break out of the loop
|
|
|
|
password_valid=1
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
ask_for_db_config
|
|
|
|
|
|
|
|
ask_for_password
|
2020-02-06 02:15:28 +00:00
|
|
|
|
|
|
|
psql -c "CREATE USER $username WITH PASSWORD '$password' SUPERUSER;" -U postgres
|
2020-05-01 13:58:52 +00:00
|
|
|
psql -c "CREATE DATABASE $dbname WITH OWNER $username;" -U postgres
|
2020-02-06 02:15:28 +00:00
|
|
|
export LEMMY_DATABASE_URL=postgres://$username:$password@localhost:$port/$dbname
|
2020-02-06 21:07:34 +00:00
|
|
|
|
2020-05-11 17:16:08 +00:00
|
|
|
echo "The database URL is $LEMMY_DATABASE_URL"
|
|
|
|
|