tweak the way postgresql.conf defines listen_addresses
[plcapi.git] / plc.d / postgresql
index 536e7c0..7e340f0 100755 (executable)
@@ -80,18 +80,12 @@ case "$1" in
        fi
 
        # Enable DB server. PostgreSQL >=8.0 defines listen_addresses,
-       # PostgreSQL 7.x uses tcpip_socket.
-       if grep -q listen_addresses $postgresql_conf ; then
-           sed -i -e '/^listen_addresses/d' $postgresql_conf
-           echo "listen_addresses = '*'" >> $postgresql_conf
-           # tweak timezone to be 'UTC'
-           sed -i -e '/^timezone=/d' $postgresql_conf
-           echo "timezone='UTC'" >> $postgresql_conf
-       else
-           dialog "PostgreSQL <= 7.x - not supported"
-           /bin/false
-           check
-       fi
+       # when run within a vserver, this may require localhost to be specified explicitly
+       sed -i -e '/^listen_addresses/d' $postgresql_conf
+       echo "listen_addresses = '${PLC_DB_HOST},localhost'" >> $postgresql_conf
+       # tweak timezone to be 'UTC'
+       sed -i -e '/^timezone=/d' $postgresql_conf
+       echo "timezone='UTC'" >> $postgresql_conf
 
        # Disable access to all DBs from all hosts
        sed -i -e '/^\(host\|local\)/d' $pghba_conf