Clean postgres driver variables and add postgres-9.1 support release_20121209
authorClinton Ebadi <clinton@unknownlamer.org>
Mon, 10 Dec 2012 01:44:38 +0000 (20:44 -0500)
committerClinton Ebadi <clinton@unknownlamer.org>
Mon, 10 Dec 2012 01:44:38 +0000 (20:44 -0500)
* Like with mysql, remove magic spaces at the end of the config
  settings
* Curry the definitions of the postgres dbms functions for
  multi-version support
* Register new postgres-9.1 dbms backend

configDefault/postgres.cfg
configDefault/postgres.csg
src/plugins/domtool-postgres
src/plugins/postgres.sml

index 6c91204..83dfe53 100644 (file)
@@ -1,7 +1,10 @@
 structure Postgres :> POSTGRES_CONFIG = struct
 
 structure Postgres :> POSTGRES_CONFIG = struct
 
-val adduser = "/usr/bin/sudo /usr/local/sbin/domtool-postgres adduser "
-val createdb = "/usr/bin/sudo /usr/local/sbin/domtool-postgres createdb "
-val dropdb = "/usr/bin/sudo /usr/local/sbin/domtool-postgres dropdb "
+val adduser = "/usr/bin/sudo /usr/local/sbin/domtool-postgres adduser"
+val createdb = "/usr/bin/sudo /usr/local/sbin/domtool-postgres createdb"
+val dropdb = "/usr/bin/sudo /usr/local/sbin/domtool-postgres dropdb"
+
+val postgres81port = "5432";
+val postgres91port = "5433"
 
 end
 
 end
index e493dbe..12c752a 100644 (file)
@@ -4,4 +4,6 @@ val adduser : string
 val createdb : string
 val dropdb : string
 
 val createdb : string
 val dropdb : string
 
+val postgres81port : string
+val postgres91port : string
 end
 end
index d05999f..03320d0 100755 (executable)
@@ -1,17 +1,19 @@
 #!/bin/sh -e
 
 #!/bin/sh -e
 
+export PGPORT="$2"
+
 case $1 in
        adduser)
 case $1 in
        adduser)
-               USERNAME=$2
+               USERNAME=$3
 
                sudo -u postgres psql -h postgres -c "CREATE USER $USERNAME" template1
                sudo -u postgres psql -h postgres -c "ALTER TABLESPACE user_$USERNAME OWNER TO $USERNAME"
        ;;
 
        createdb)
 
                sudo -u postgres psql -h postgres -c "CREATE USER $USERNAME" template1
                sudo -u postgres psql -h postgres -c "ALTER TABLESPACE user_$USERNAME OWNER TO $USERNAME"
        ;;
 
        createdb)
-               USERNAME=$2
-               DBNAME_BASE=$3
-               ENCODING=$4
+               USERNAME=$3
+               DBNAME_BASE=$4
+               ENCODING=$5
                DBNAME="${USERNAME}_${DBNAME_BASE}"
 
                if [ -n "$ENCODING" ]; then
                DBNAME="${USERNAME}_${DBNAME_BASE}"
 
                if [ -n "$ENCODING" ]; then
@@ -22,8 +24,8 @@ case $1 in
        ;;
 
        dropdb)
        ;;
 
        dropdb)
-               USERNAME=$2
-               DBNAME_BASE=$3
+               USERNAME=$3
+               DBNAME_BASE=$4
                DBNAME="${USERNAME}_${DBNAME_BASE}"
 
                sudo -u postgres dropdb -h postgres $DBNAME
                DBNAME="${USERNAME}_${DBNAME_BASE}"
 
                sudo -u postgres dropdb -h postgres $DBNAME
index 6465377..607cf0d 100644 (file)
 
 structure Postgres :> POSTGRES = struct
 
 
 structure Postgres :> POSTGRES = struct
 
-fun adduser {user, passwd} =
+fun adduser port {user, passwd} =
     Option.map (fn s => "Error executing CREATE USER script:\n" ^ s)
     Option.map (fn s => "Error executing CREATE USER script:\n" ^ s)
-              (Slave.shellOutput [Config.Postgres.adduser, user])
+              (Slave.shellOutput [Config.Postgres.adduser, " ", port, " ", user])
 
 fun passwd _ = SOME "We don't use PostgreSQL passwords."
 
 
 fun passwd _ = SOME "We don't use PostgreSQL passwords."
 
-fun createdb {user, dbname, encoding} =
+fun createdb port {user, dbname, encoding} =
     Option.map (fn s => "Error executing CREATE DATABASE script:\n" ^ s)
               (Slave.shellOutput [Config.Postgres.createdb,
     Option.map (fn s => "Error executing CREATE DATABASE script:\n" ^ s)
               (Slave.shellOutput [Config.Postgres.createdb,
-                                  " ", user, " ", dbname,
+                                  " ", port, " ", user, " ", dbname,
                                   case encoding of NONE => "" | SOME e => " " ^ e])
 
                                   case encoding of NONE => "" | SOME e => " " ^ e])
 
-fun dropdb {user, dbname} =
+fun dropdb port {user, dbname} =
     Option.map (fn s => "Error executing DROP DATABASE script:\n" ^ s)
     Option.map (fn s => "Error executing DROP DATABASE script:\n" ^ s)
-              (Slave.shellOutput [Config.Postgres.dropdb, user, " ", dbname])
+              (Slave.shellOutput [Config.Postgres.dropdb, " ", port, " ", user, " ", dbname])
 
 val _ = Dbms.register ("postgres", {getpass = NONE,
 
 val _ = Dbms.register ("postgres", {getpass = NONE,
-                                   adduser = adduser,
+                                   adduser = adduser Config.Postgres.postgres81port,
                                    passwd = passwd,
                                    passwd = passwd,
-                                   createdb = createdb,
-                                   dropdb = dropdb,
+                                   createdb = createdb Config.Postgres.postgres81port,
+                                   dropdb = dropdb Config.Postgres.postgres81port,
                                    grant = fn _ => SOME "You don't need to use GRANT for Postgres."})
 
                                    grant = fn _ => SOME "You don't need to use GRANT for Postgres."})
 
+val _ = Dbms.register ("postgres-9.1", {getpass = NONE,
+                                       adduser = adduser Config.Postgres.postgres91port,
+                                       passwd = passwd,
+                                       createdb = createdb Config.Postgres.postgres91port,
+                                       dropdb = dropdb Config.Postgres.postgres91port,
+                                       grant = fn _ => SOME "You don't need to use GRANT for Postgres."})
+
 end
 end