summaryrefslogtreecommitdiffstats
path: root/server/db-init.sh
blob: ccecb7de717892efb4c72128656f67b42c7769dc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#!/bin/bash
set -e

# Default configurations
username=lemmy
dbname=lemmy
port=5432

yes_no_prompt_invalid() {
  echo "Invalid input. Please enter either \"y\" or \"n\"." 1>&2
}

print_config() {
  echo "  database name: $dbname"
  echo "  username: $username"
  echo "  port: $port"
}

ask_for_db_config() {
  echo "The default database configuration is:"
  print_config
  echo

  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
    echo
  done

  if [ "$default_config_final" == 0 ]
  then
    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
  fi
}

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

    # 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

    # Set the password_valid variable to break out of the loop
    password_valid=1
  done
}

ask_for_db_config

ask_for_password

psql -c "CREATE USER $username WITH PASSWORD '$password' SUPERUSER;" -U postgres
psql -c "CREATE DATABASE $dbname WITH OWNER $username;" -U postgres
export LEMMY_DATABASE_URL=postgres://$username:$password@localhost:$port/$dbname

echo "The database URL is $LEMMY_DATABASE_URL"