소스 검색

new package: postgresql82 8.2b3 (PostgreSQL Database (BETA VERSION))

Ralf S. Engelschall 19 년 전
부모
커밋
16feabd679
4개의 변경된 파일1071개의 추가작업 그리고 0개의 파일을 삭제
  1. 204 0
      postgresql82/pg_migrate
  2. 19 0
      postgresql82/postgresql82.patch
  3. 740 0
      postgresql82/postgresql82.spec
  4. 108 0
      postgresql82/rc.postgresql

+ 204 - 0
postgresql82/pg_migrate

@@ -0,0 +1,204 @@
+#!/bin/sh
+##
+##  pg_migrate -- PostgreSQL Database Migration Utility
+##  Copyright (c) 2000-2006 OpenPKG Foundation e.V. <http://openpkg.net/>
+##  Copyright (c) 2000-2006 Ralf S. Engelschall <http://engelschall.com/>
+##
+##  Permission to use, copy, modify, and distribute this software for
+##  any purpose with or without fee is hereby granted, provided that
+##  the above copyright notice and this permission notice appear in all
+##  copies.
+##
+##  THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+##  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+##  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+##  IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
+##  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+##  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+##  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+##  USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+##  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+##  OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+##  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+##  SUCH DAMAGE.
+##
+
+#   configuration
+l_prefix="@l_prefix@"
+l_rusr="@l_rusr@"
+l_rgrp="@l_rgrp@"
+l_pguser="@l_pguser@"
+l_pgpass="@l_pgpass@"
+
+#   establish sane environment
+LC_CTYPE=C
+export LC_CTYPE
+umask 022
+
+#   check command line
+if [ $# -ne 1 ]; then
+    echo "$0:ERROR: invalid command line" 1>&2
+    echo "$0:USAGE: $0 dump|restore" 1>&2
+    exit 1
+fi
+
+#   dispatch into commands
+cmd="$1"
+shift
+case $cmd in
+    dump )
+        echo "++ enforcing full-superuser access policy"
+        cp -p $l_prefix/var/postgresql/db/pg_hba.conf \
+              $l_prefix/var/postgresql/db/pg_hba.conf.orig
+        ( echo "local all trust"
+          echo "host all 127.0.0.1 255.255.255.255 trust"
+        ) >$l_prefix/var/postgresql/db/pg_hba.conf
+
+        if [ ".`$l_prefix/etc/rc postgresql status 2>&1 | grep 'is running'`" != . ]; then
+            echo "++ reloading already running database engine"
+            $l_prefix/etc/rc postgresql reload
+            sleep 2
+            epilog=reload
+        else
+            echo "++ temporarily starting database engine"
+            $l_prefix/etc/rc postgresql start 
+            sleep 4
+            epilog=stop
+        fi
+
+        echo "++ rotating dump files $l_prefix/var/postgresql/db.dump*.sql.bz2"
+        i=9
+        rm -f $l_prefix/var/postgresql/db.dump.$i.sql.bz2 >/dev/null 2>&1 || true
+        while [ $i -gt 0 ]; do
+            j=$i
+            i=`expr $i - 1`
+            if [ $i -eq 0 ]; then
+                prev="$l_prefix/var/postgresql/db.dump.sql.bz2"
+                next="$l_prefix/var/postgresql/db.dump.$j.sql.bz2"
+            else
+                prev="$l_prefix/var/postgresql/db.dump.$i.sql.bz2"
+                next="$l_prefix/var/postgresql/db.dump.$j.sql.bz2"
+            fi
+            if [ -f $prev ]; then
+                mv $prev $next
+            fi
+        done
+
+        echo "++ dumping all databases into $l_prefix/var/postgresql/db.dump.sql.bz2"
+        PGPASSWORD="$l_pgpass" \
+        $l_prefix/bin/pg_dumpall \
+            -U $l_pguser -o |\
+            $l_prefix/lib/openpkg/bzip2 -9 \
+                >$l_prefix/var/postgresql/db.dump.sql.bz2
+        chown ${l_rusr}:${l_rgrp} $l_prefix/var/postgresql/db.dump.sql.bz2
+        chmod 700 $l_prefix/var/postgresql/db.dump.sql.bz2
+
+        echo "++ restoring original access policy"
+        cp -p $l_prefix/var/postgresql/db/pg_hba.conf.orig \
+              $l_prefix/var/postgresql/db/pg_hba.conf
+        rm -f $l_prefix/var/postgresql/db/pg_hba.conf.orig
+
+        if [ ".$epilog" = .reload ]; then
+            echo "++ reloading already running database engine (again)"
+            $l_prefix/etc/rc postgresql reload
+            sleep 2
+        else
+            echo "++ stopping temporarily started database engine"
+            $l_prefix/etc/rc postgresql stop 
+            sleep 4
+        fi
+        ;;
+
+    restore )
+        if [ ".`$l_prefix/etc/rc postgresql status 2>&1 | grep 'is running'`" != . ]; then
+            echo "++ stopping already running database engine"
+            $l_prefix/etc/rc postgresql stop
+            sleep 2
+            epilog=start
+        else
+            epilog=none
+        fi
+
+        echo "++ rotating database directories $l_prefix/var/postgresql/db.old*/"
+        i=9
+        rm -rf $l_prefix/var/postgresql/db.old.$i >/dev/null 2>&1 || true
+        while [ $i -gt 0 ]; do
+            j=$i
+            i=`expr $i - 1`
+            if [ $i -eq 0 ]; then
+                prev="$l_prefix/var/postgresql/db"
+                next="$l_prefix/var/postgresql/db.old.$j"
+            else
+                prev="$l_prefix/var/postgresql/db.old.$i"
+                next="$l_prefix/var/postgresql/db.old.$j"
+            fi
+            if [ -d $prev ]; then
+                mv $prev $next
+            fi
+        done
+
+        echo "++ creating new database directory $l_prefix/var/postgresql/db/"
+        mkdir $l_prefix/var/postgresql/db
+        chown ${l_rusr}:${l_rgrp} $l_prefix/var/postgresql/db
+        chmod 700 $l_prefix/var/postgresql/db
+
+        su - ${l_rusr} -c \
+            "LC_CTYPE=C; export LC_CTYPE; umask 022; \
+            echo $l_pgpass >$l_prefix/var/postgresql/run/pw; \
+            $l_prefix/bin/pg_initdb \
+                -U $l_pguser --pwfile=$l_prefix/var/postgresql/run/pw \
+                -D $l_prefix/var/postgresql/db; \
+            rm -f $l_prefix/var/postgresql/run/pw" 2>&1 |\
+        $l_prefix/lib/openpkg/shtool prop \
+            -p "++ creating new database data"
+
+        echo "++ restoring database configurations"
+        for conf in pg_hba.conf pg_ident.conf postgresql.conf; do
+            cp -p $l_prefix/var/postgresql/db.old.1/$conf \
+                  $l_prefix/var/postgresql/db/
+        done
+
+        echo "++ enforcing full-superuser access policy"
+        cp -p $l_prefix/var/postgresql/db/pg_hba.conf \
+              $l_prefix/var/postgresql/db/pg_hba.conf.orig
+        ( echo "local all trust"
+          echo "host all 127.0.0.1 255.255.255.255 trust"
+        ) >$l_prefix/var/postgresql/db/pg_hba.conf
+
+        if [ ".$epilog" = .start ]; then
+            echo "++ starting database engine"
+        else
+            echo "++ temporarily starting database engine"
+        fi
+        $l_prefix/etc/rc postgresql start
+        sleep 4
+
+        echo "++ restoring all databases from $l_prefix/var/postgresql/db.dump.sql.bz2"
+        $l_prefix/lib/openpkg/bzip2 -c -d \
+            $l_prefix/var/postgresql/db.dump.sql.bz2 |\
+                $l_prefix/bin/psql -U $l_pguser -d template1 2>&1 |\
+                    tee $l_prefix/var/postgresql/db.log |\
+                        $l_prefix/lib/openpkg/shtool prop \
+                            -p "++ restoring data (see $l_prefix/var/postgresql/db.log)"
+
+        echo "++ restoring original access policy"
+        cp -p $l_prefix/var/postgresql/db/pg_hba.conf.orig \
+              $l_prefix/var/postgresql/db/pg_hba.conf
+        rm -f $l_prefix/var/postgresql/db/pg_hba.conf.orig
+
+        if [ ".$epilog" = .start ]; then
+            echo "++ reloading already running database engine"
+            $l_prefix/etc/rc postgresql reload
+            sleep 2
+        else
+            echo "++ stopping temporarily started database engine"
+            $l_prefix/etc/rc postgresql stop 
+            sleep 4
+        fi
+        ;;
+    * )
+        echo "$0:ERROR: unknown command \"$cmd\"" 1>&2
+        exit 1
+        ;;
+esac
+

+ 19 - 0
postgresql82/postgresql82.patch

@@ -0,0 +1,19 @@
+Index: src/template/freebsd
+--- src/template/freebsd.orig	2006-03-11 05:38:41 +0100
++++ src/template/freebsd	2006-11-20 20:54:27 +0100
+@@ -1,5 +1,5 @@
+ # $PostgreSQL: pgsql/src/template/freebsd,v 1.35 2006/03/11 04:38:41 momjian Exp $
+ 
+ case $host_cpu in
+-  alpha*)   CFLAGS="-O";;  # alpha has problems with -O2
++  alpha*)   CFLAGS=`echo "x$CFLAGS" | sed -e 's;^x;;' -e 's;-O2;-O;'`;;  # alpha has problems with -O2
+ esac
+Index: src/template/linux
+--- src/template/linux.orig	2006-03-11 05:38:41 +0100
++++ src/template/linux	2006-11-20 20:54:27 +0100
+@@ -1,4 +1,4 @@
+ # $PostgreSQL: pgsql/src/template/linux,v 1.28 2006/03/11 04:38:41 momjian Exp $
+ 
+ # Force _GNU_SOURCE on; plperl is broken with Perl 5.8.0 otherwise
+-CPPFLAGS="-D_GNU_SOURCE"
++CPPFLAGS="$CPPFLAGS -D_GNU_SOURCE"

+ 740 - 0
postgresql82/postgresql82.spec

@@ -0,0 +1,740 @@
+##
+##  postgresql82.spec -- OpenPKG RPM Package Specification
+##  Copyright (c) 2000-2006 OpenPKG Foundation e.V. <http://openpkg.net/>
+##  Copyright (c) 2000-2006 Ralf S. Engelschall <http://engelschall.com/>
+##
+##  Permission to use, copy, modify, and distribute this software for
+##  any purpose with or without fee is hereby granted, provided that
+##  the above copyright notice and this permission notice appear in all
+##  copies.
+##
+##  THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+##  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+##  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+##  IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
+##  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+##  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+##  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+##  USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+##  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+##  OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+##  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+##  SUCH DAMAGE.
+##
+
+#   package versions
+%define       V_postgresql_base 8.2
+%define       V_postgresql_beta 3
+%define       V_libpqpp         4.0
+%define       V_libpqxx         2.5.5
+%define       V_pgperl          2.0.2
+%define       V_psqlodbc        08.02.0200
+%define       V_slony1          1.1.5
+%define       V_pgcluster       1.5.0rc9
+%define       V_pgcluster_dir   1123
+%define       V_mysqlcompat     1.0b3
+%define       V_mysqlcompat_dir 548
+
+#   package information
+Name:         postgresql82
+Summary:      PostgreSQL Database (BETA VERSION)
+URL:          http://www.postgresql.org/
+Vendor:       PostgreSQL Group
+Packager:     OpenPKG Foundation e.V.
+Distribution: OpenPKG Community
+Class:        BASE
+Group:        Database
+License:      GPL
+Version:      %{V_postgresql_base}b%{V_postgresql_beta}
+Release:      20061120
+
+#   package options
+%option       with_server       yes
+%option       with_cxx          no
+%option       with_perl         no
+%option       with_odbc         no
+%option       with_compat       no
+%option       with_tcl          no
+%option       with_slony1       no
+%option       with_pgcluster    no
+%option       with_kerberos     no
+%option       with_mysqlcompat  no
+%option       with_int_datetime no
+%option       with_setproctitle no
+
+#   list of sources
+Source0:      ftp://ftp.postgresql.org/pub/source/v%{V_postgresql_base}beta/postgresql-%{V_postgresql_base}beta%{V_postgresql_beta}.tar.gz
+Source1:      ftp://gborg.postgresql.org/pub/libpqpp/stable/libpq++-%{V_libpqpp}.tar.gz
+Source2:      ftp://gborg.postgresql.org/pub/libpqxx/stable/libpqxx-%{V_libpqxx}.tar.gz
+Source3:      ftp://gborg.postgresql.org/pub/pgperl/stable/pgperl-%{V_pgperl}.tar.gz
+Source4:      ftp://ftp.postgresql.org/pub/odbc/versions/src/psqlodbc-%{V_psqlodbc}.tar.gz
+Source5:      http://developer.postgresql.org/~wieck/slony1/download/slony1-%{V_slony1}.tar.bz2
+Source6:      http://pgfoundry.org/frs/download.php/%{V_pgcluster_dir}/pgcluster-%{V_pgcluster}-patch.tar.gz
+Source7:      http://pgfoundry.org/frs/download.php/%{V_mysqlcompat_dir}/mysqlcompat-%{V_mysqlcompat}.tar.gz
+Source8:      rc.postgresql
+Source9:      pg_migrate
+Patch0:       postgresql82.patch
+
+#   build information
+Prefix:       %{l_prefix}
+BuildRoot:    %{l_buildroot}
+BuildPreReq:  OpenPKG, openpkg >= 20060823, make, gcc, flex, bison, gzip
+PreReq:       OpenPKG, openpkg >= 20060823
+BuildPreReq:  readline, zlib, openssl, getopt
+PreReq:       readline, zlib, openssl, getopt
+%if "%{with_perl}" == "yes"
+BuildPreReq:  perl, perl-openpkg >= 5.8.3-20040126
+PreReq:       perl
+%endif
+%if "%{with_odbc}" == "yes"
+BuildPreReq:  unixodbc
+PreReq:       unixodbc
+%endif
+%if "%{with_tcl}" == "yes"
+BuildPreReq:  tcl, tcl::with_x11 = yes, X11
+PreReq:       tcl, tcl::with_x11 = yes, X11
+%endif
+%if "%{with_kerberos}" == "yes"
+BuildPreReq:  kerberos
+PreReq:       kerberos
+%endif
+AutoReq:      no
+AutoReqProv:  no
+Provides:     postgresql = %{version}-%{release}
+Conflicts:    postgresql
+
+%description
+    PostgreSQL is a sophisticated Object-Relational Database Management
+    System (ORDBMS). It is fully ACID compliant and has full support
+    for foreign keys, joins, views, triggers, and stored procedures (in
+    multiple languages). It includes most SQL92 and SQL99 data types
+    and also supports storage of binary large objects. It is the most
+    advanced Open-Source RDBMS available anywhere.
+
+    As an enterprise class RDBMS, PostgreSQL boasts sophisticated
+    features such as Multi-Version Concurrency Control (MVCC), Point In
+    Time Recovery (PITR), tablespaces, asynchronous replication, nested
+    transactions (savepoints), online/hot backups, a sophisticated
+    query planner/optimizer, and Write Ahead Logging (WAL) for fault
+    tolerance. It supports international character sets, multibyte
+    character encodings, Unicode, and it is locale-aware for sorting,
+    case-sensitivity, and formatting. It is highly scalable both in the
+    sheer quantity of data it can manage and in the number of concurrent
+    users it can accommodate.
+
+    NOTICE: THIS IS AN EXPERIMENTAL BETA VERSION!
+
+%track
+    prog postgresql82 = {
+        version   = %{V_postgresql_base}beta%{V_postgresql_beta}
+        url       = ftp://ftp.postgresql.org/pub/source/
+        regex     = v(8\.2(\.\d+)*(beta)?)
+        url       = ftp://ftp.postgresql.org/pub/source/v__NEWVER__/
+        regex     = postgresql-(\d+\.\d+(\.\d+)*(beta\d+)?)\.tar\.(?:gz|bz2)
+    }
+    prog postgresql82:libpq++ = {
+        version   = %{V_libpqpp}
+        url       = ftp://gborg.postgresql.org/pub/libpqpp/stable/
+        regex     = libpq\+\+-(__VER__)\.tar\.gz
+    }
+    prog postgresql82:libpqxx = {
+        version   = %{V_libpqxx}
+        url       = ftp://gborg.postgresql.org/pub/libpqxx/stable/
+        regex     = libpqxx-(__VER__)\.tar\.gz
+    }
+    prog postgresql82:pgperl = {
+        version   = %{V_pgperl}
+        url       = ftp://gborg.postgresql.org/pub/pgperl/stable/
+        regex     = pgperl-(__VER__)\.tar\.gz
+    }
+    prog postgresql82:psqlodbc = {
+        version   = %{V_psqlodbc}
+        url       = ftp://ftp.postgresql.org/pub/odbc/versions/src/
+        regex     = psqlodbc-(\d{2}\.\d{2}\.\d{4})\.tar\.gz
+    }
+    prog postgresql82:slony1 = {
+        version   = %{V_slony1}
+        url       = http://developer.postgresql.org/~wieck/slony1/download/
+        regex     = slony1-(\d+\.\d+\.\d+)\.tar\.bz2
+    }
+    prog postgresql82:pgcluster = {
+        version   = %{V_pgcluster}.%{V_pgcluster_dir}
+        url       = http://pgfoundry.org/frs/?group_id=1000072&release_id=168
+        regex     = /(\d+/pgcluster-__VER__)-patch\.tar\.gz
+        transform = "s/^(\\d+)\/pgcluster-(.+)$/$2.$1/; $_"
+    }
+    prog postgresql82:mysqlcompat = {
+        version   = %{V_mysqlcompat}.%{V_mysqlcompat_dir}
+        url       = http://pgfoundry.org/frs/?group_id=1000154&release_id=379
+        regex     = (\d+/mysqlcompat-__VER__)\.tar\.gz
+        transform = "s/^(\\d+)\/mysqlcompat-(.+)$/$2.$1/; $_"
+    }
+
+%prep
+    %setup -q -n postgresql-%{V_postgresql_base}beta%{V_postgresql_beta}
+    %patch -p0
+%if "%{with_cxx}" == "yes"
+    %setup -q -T -D -a 1
+    %setup -q -T -D -a 2
+    case "%{l_platform -t}" in
+        *-sunos* )
+            %{l_shtool} subst \
+                -e 's;strerror_r(0,0,0);strerror((int)0);g' \
+                -e 's;strerror_r((int)0, (char \*)0, (size_t)0);strerror((int)0);g' \
+                libpqxx-%{V_libpqxx}/configure
+            %{l_shtool} subst \
+                -e 's;strerror_r(err, buf, sizeof(buf));strerror(err);g' \
+                libpqxx-%{V_libpqxx}/src/largeobject.cxx \
+                libpqxx-%{V_libpqxx}/configure
+            %{l_shtool} subst \
+                -e 's;\(strerror(err) ==\) -1;\1 (char *)-1;' \
+                libpqxx-%{V_libpqxx}/src/largeobject.cxx
+            ;;
+    esac
+    %{l_shtool} subst \
+        -e 's;^function \(add_compiler_opts() {\);\1;' \
+        libpqxx-%{V_libpqxx}/configure
+%endif
+%if "%{with_perl}" == "yes"
+    %setup -q -T -D -a 3
+%endif
+%if "%{with_odbc}" == "yes"
+    %setup -q -T -D -a 4
+%endif
+%if "%{with_slony1}" == "yes"
+    %setup -q -T -D -a 5
+%endif
+%if "%{with_pgcluster}" == "yes"
+    %setup -q -T -D -a 6
+    sed -e '/^diff.*libpq\.rc/,/^diff/d' pgcluster-*-patch |\
+    sed -e 's;(char .)\(ptr .= readlen\);\1;' |\
+    %{l_patch} -p1
+%endif
+%if "%{with_mysqlcompat}" == "yes"
+    %setup -q -T -D -a 7
+%endif
+%if "%{with_kerberos}" == "yes"
+    %{l_shtool} subst \
+        -e 's;krb5 -ldes -lasn1 -lroken;krb5 -lk5crypto -lkrb5support -lcom_err;g' \
+        configure
+%endif
+
+    #   adjust source tree
+    %{l_shtool} subst \
+        -e 's;\(#define.*DEFAULT_PGSOCKET_DIR[^"]*"\)/tmp\("\);\1%{l_prefix}/var/postgresql/run\2;' \
+        src/include/pg_config_manual.h
+    %{l_shtool} subst \
+        -e 's;^\(sqlmansect *=\).*$;\1 7;' \
+        src/makefiles/Makefile.solaris
+    %{l_shtool} subst \
+        -e 's;$(INSTALL_SHLIB);#$(INSTALL_SHLIB);g' \
+        src/backend/utils/mb/conversion_procs/proc.mk
+    %{l_shtool} subst \
+        -e 's;# Shared library stuff;enable_shared = yes;g' \
+        src/pl/plpgsql/src/Makefile
+
+%build
+    rm -rf $RPM_BUILD_ROOT
+
+    #   configure package
+    ( echo "ac_cv_func_isinf=no"
+%if "%{with_setproctitle}" == "no"
+      echo "ac_cv_lib_util_setproctitle=no"
+      echo "ac_cv_func_setproctitle=no"
+      echo "ac_cv_func_setproctitle_func=no"
+%endif
+    ) >config.cache
+    export CC="%{l_cc}"
+    export CFLAGS="%{l_cflags -O}"
+    export CPPFLAGS="%{l_cppflags readline} -DOPENSSL_DISABLE_OLD_DES_SUPPORT"
+    export LDFLAGS="%{l_ldflags}"
+%if "%{with_slony1}" == "yes"
+    CFLAGS="$CFLAGS -pthread"
+%endif
+%if "%{with_tcl}" == "yes"
+    CPPFLAGS="$CPPFLAGS %{l_cppflags tcl}"
+    LDFLAGS="$LDFLAGS -L`%{l_rc} --query x11_libdir`"
+%endif
+%if "%{with_kerberos}" == "yes"
+    CPPFLAGS="$CPPFLAGS %{l_cppflags kerberos}"
+    LDFLAGS="$LDFLAGS %{l_ldflags kerberos}"
+%endif
+    export TAR="%{l_tar}"
+    export YACC="bison -y"
+    ./configure \
+        --cache-file=./config.cache \
+        --prefix=%{l_prefix} \
+        --sysconfdir=%{l_prefix}/etc/postgresql \
+        --includedir=%{l_prefix}/include/postgresql \
+        --with-openssl \
+        --with-readline \
+        --with-zlib \
+%if "%{with_tcl}" == "yes"
+        --with-tcl \
+        --with-tclconfig="%{l_prefix}/lib" \
+        --with-tkconfig="%{l_prefix}/lib" \
+%endif
+%if "%{with_slony1}" == "yes"
+        --enable-thread-safety \
+%endif
+%if "%{with_kerberos}" == "yes"
+        --with-krb5 \
+        --with-krb-srvnam=postgresql \
+%endif
+%if "%{with_int_datetime}" == "yes"
+        --enable-integer-datetimes \
+%endif
+        --disable-syslog \
+        --disable-shared
+
+    #   build package
+    %{l_make} %{l_mflags}
+
+    #   build C++ bindings (both old and new one)
+%if "%{with_cxx}" == "yes"
+    ( cd libpq++-%{V_libpqpp}
+      CXX="%{l_cxx}"
+      CFLAGS="%{l_cflags -O}"
+      CPPFLAGS="-DHAVE_NAMESPACE_STD -DHAVE_CXX_STRING_HEADER -DDLLIMPORT= "
+      CPPFLAGS="$CPPFLAGS -I. -I../src/interfaces/libpq -I../src/interfaces"
+      CPPFLAGS="$CPPFLAGS -I../src/include %{l_cppflags}"
+      LDFLAGS="%{l_ldflags}"
+      OBJS="pgconnection.o pgdatabase.o pgtransdb.o pgcursordb.o pglobject.o"
+      for o in $OBJS; do
+          $CXX $CFLAGS $CPPFLAGS $LDFLAGS -c -o $o `echo $o | sed -e 's;\.o$;.cc;'`
+      done
+      rm -f libpq++.a
+      ar rc libpq++.a $OBJS
+    ) || exit $?
+    ln -s `pwd`/src/interfaces/libpq/*.h src/include/
+    ( cd libpqxx-%{V_libpqxx}
+      %{l_shtool} subst \
+          -e 's;\(cut\)\( .*/configitems\)\( -f [0-9]\);\1\3\2;g' \
+          configure
+      ( echo "#!/bin/sh"
+        echo "case \"\$1\" in"
+        echo "   --includedir ) echo \"`pwd`/../src/include\" ;;"
+        echo "   --libdir     ) echo \"`pwd`/../src/interfaces/libpq\" ;;"
+        echo "esac"
+      ) >pg_config
+      chmod a+x pg_config
+      export PG_CONFIG=`pwd`/pg_config
+      export CC="%{l_cc}"
+      export CXX="%{l_cxx}"
+      export CFLAGS="%{l_cflags -O}"
+      export CXXFLAGS="%{l_cxxflags -O}"
+      export CPPFLAGS="-I`pwd`/../src/include %{l_cppflags}"
+      export LDFLAGS="%{l_ldflags}"
+      export LIBS="-lssl -lcrypto -lcrypt"
+      case "%{l_platform -t}" in
+          *-sunos* ) LIBS="$LIBS -lsocket -lnsl" ;;
+      esac
+      ./configure \
+          --disable-shared
+      %{l_make} %{l_mflags -O}
+    ) || exit $?
+%endif
+
+    #   build Perl bindings
+%if "%{with_perl}" == "yes"
+    %{l_prefix}/bin/perl-openpkg prepare
+    ( cd Pg-%{V_pgperl}
+      export POSTGRES_INCLUDE=dummy
+      export POSTGRES_LIB=dummy
+      %{l_shtool} subst \
+          -e 's;-I$POSTGRES_INCLUDE;-I../src/interfaces/libpq -I../src/include;' \
+          -e 's;-L$POSTGRES_LIB;-L../src/interfaces/libpq;' \
+          -e 's;-lpq;-lpq %{l_ldflags} -lssl -lcrypto -lcrypt;' \
+          Makefile.PL
+    ) || exit $?
+    ( export POSTGRES_INCLUDE=dummy
+      export POSTGRES_LIB=dummy
+      %{l_prefix}/bin/perl-openpkg -d Pg-%{V_pgperl} configure build
+    ) || exit $?
+%endif
+
+    #   build ODBC driver
+%if "%{with_odbc}" == "yes"
+    ( cd psqlodbc-%{V_psqlodbc}
+      export CC="%{l_cc}"
+      export CXX="%{l_cxx}"
+      export CFLAGS="%{l_cflags -O}"
+      export CXXFLAGS="%{l_cxxflags -O}"
+      export CPPFLAGS="-I`pwd`/../src/include"
+      CPPFLAGS="$CPPFLAGS -I`pwd`/../src/interfaces -I`pwd`/../src/interfaces/libpq"
+      CPPFLAGS="$CPPFLAGS %{l_cppflags}"
+      export LDFLAGS="-L`pwd`/../src/interfaces/libpq %{l_ldflags}"
+      ./configure \
+          --prefix=%{l_prefix} \
+          --with-unixodbc \
+          --with-odbcinst=%{l_prefix}/etc/unixodbc
+      %{l_make} %{l_mflags -O}
+    ) || exit $?
+%endif
+
+    #   build Slony-1 replication engine
+%if "%{with_slony1}" == "yes"
+    ( cd slony1-%{V_slony1}
+      ln  ../src/pl/plpgsql/src/libplpgsql.so \
+          ../src/pl/plpgsql/src/plpgsql.so
+      %{l_shtool} subst \
+          -e 's;-lpq;-lpq -lssl -lcrypto -lcrypt;' \
+          src/slon/Makefile src/slonik/Makefile
+      export CC="%{l_cc}"
+      export CFLAGS="%{l_cflags -O}"
+      export CPPFLAGS="%{l_cppflags}"
+      export LDFLAGS="%{l_ldflags}"
+      export LIBS="-lssl -lcrypto -lcrypt"
+      ./configure \
+          --prefix=%{l_prefix} \
+          --sysconfdir=%{l_prefix}/etc/postgresql \
+          --with-pgconfigdir=../src/bin/pg_config \
+          --with-pgincludedir=../src/include \
+          --with-pgincludeserverdir=../src/interfaces/libpq \
+          --with-pglibdir=../src/interfaces/libpq \
+          --with-pgpkglibdir=../src/pl/plpgsql/src \
+          --with-pgsharedir=../src/backend/utils/misc
+      %{l_make} %{l_mflags -O}
+    ) || exit $?
+%endif
+
+    #   rebuild pg_config with hard-coded path to avoid that it provides
+    #   dynamically resolved paths which circumvent symlinks, etc.
+    ( cd src/bin/pg_config
+      %{l_shtool} subst \
+          -e 's:find_my_exec(argv.0., mypath):0; strcpy(mypath, "%{l_prefix}/bin/pg_config"):' \
+          pg_config.c
+      %{l_make} %{l_mflags}
+    ) || exit $?
+
+%install
+    rm -rf $RPM_BUILD_ROOT
+
+    #   perform standard installation procedure
+    cp /dev/null register.txt
+    %{l_make} %{l_mflags} install DESTDIR=$RPM_BUILD_ROOT
+
+    #   strip down installation
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/doc
+    strip $RPM_BUILD_ROOT%{l_prefix}/bin/* >/dev/null 2>&1 || true
+    rm -f $RPM_BUILD_ROOT%{l_prefix}/man/man1/pgaccess.1
+    rm -f $RPM_BUILD_ROOT%{l_prefix}/man/man1/pgtclsh.1
+    rm -f $RPM_BUILD_ROOT%{l_prefix}/man/man1/pgtksh.1
+
+    #   namespace adjustments to installation
+    for prog in \
+        createdb createlang createuser dropdb droplang clusterdb \
+        dropuser initdb ipcclean vacuumdb reindexdb; do
+%if "%{with_compat}" == "yes"
+        cmd="ln"
+%else
+        cmd="mv"
+%endif
+        $cmd $RPM_BUILD_ROOT%{l_prefix}/bin/$prog \
+             $RPM_BUILD_ROOT%{l_prefix}/bin/pg_$prog
+        $cmd $RPM_BUILD_ROOT%{l_prefix}/man/man1/$prog.1 \
+             $RPM_BUILD_ROOT%{l_prefix}/man/man1/pg_$prog.1
+    done
+    ( cd $RPM_BUILD_ROOT%{l_prefix}/man/man7
+      for man in *.7; do
+          mv $man pg_$man
+      done
+    ) || exit $?
+
+    #   create additional directories
+    %{l_shtool} mkdir -f -p -m 755 \
+%if "%{with_slony1}" == "yes" || "%{with_pgcluster}" == "yes"
+        $RPM_BUILD_ROOT%{l_prefix}/etc/postgresql \
+%endif
+        $RPM_BUILD_ROOT%{l_prefix}/var/postgresql/db \
+        $RPM_BUILD_ROOT%{l_prefix}/var/postgresql/run
+
+    #   install migration utility
+%if "%{with_compat}" == "yes"
+    l_pguser="postgres"
+    l_pgpass="postgres"
+%else
+    l_pguser="postgresql"
+    l_pgpass="postgresql"
+%endif
+    %{l_shtool} install -c -m 755 %{l_value -s -a} \
+        -e "s;@l_pguser@;${l_pguser};g" \
+        -e "s;@l_pgpass@;${l_pgpass};g" \
+        %{SOURCE pg_migrate} \
+        $RPM_BUILD_ROOT%{l_prefix}/bin/
+
+    #   install C++ bindings (both old and new one)
+%if "%{with_cxx}" == "yes"
+    ( cd libpq++-%{V_libpqpp}
+      %{l_shtool} mkdir -f -p -m 755 \
+          $RPM_BUILD_ROOT%{l_prefix}/include/libpq++
+      %{l_shtool} install -c -m 644 \
+          libpq++.h pgconnection.h pgdatabase.h pgtransdb.h pgcursordb.h pglobject.h \
+          $RPM_BUILD_ROOT%{l_prefix}/include/libpq++/
+      %{l_shtool} install -c -m 644 \
+          libpq++.a \
+          $RPM_BUILD_ROOT%{l_prefix}/lib/
+    ) || exit $?
+    ( cd libpqxx-%{V_libpqxx}
+      %{l_shtool} mkdir -f -p -m 755 \
+          $RPM_BUILD_ROOT%{l_prefix}/include/pqxx
+      %{l_shtool} install -c -m 644 \
+          include/pqxx/* \
+          $RPM_BUILD_ROOT%{l_prefix}/include/pqxx/
+      rm -f $RPM_BUILD_ROOT%{l_prefix}/include/pqxx/Makefile*
+      rm -f $RPM_BUILD_ROOT%{l_prefix}/include/pqxx/config.h*
+      %{l_shtool} install -c -m 644 \
+          src/.libs/libpqxx.a \
+          $RPM_BUILD_ROOT%{l_prefix}/lib/
+    ) || exit $?
+%endif
+
+    #   install Perl binding
+%if "%{with_perl}" == "yes"
+    ( export POSTGRES_INCLUDE=dummy
+      export POSTGRES_LIB=dummy
+      %{l_prefix}/bin/perl-openpkg -d Pg-%{V_pgperl} install
+    ) || exit $?
+    %{l_prefix}/bin/perl-openpkg -F perl-openpkg-files fixate cleanup
+%else
+    >perl-openpkg-files
+%endif
+
+    #   install ODBC driver
+%if "%{with_odbc}" == "yes"
+    ( cd psqlodbc-%{V_psqlodbc}
+      %{l_make} %{l_mflags} install AM_MAKEFLAGS="DESTDIR=$RPM_BUILD_ROOT"
+    ) || exit $?
+%endif
+
+    #   install Slony-1 replication engine
+%if "%{with_slony1}" == "yes"
+    ( cd slony1-%{V_slony1}
+      %{l_make} %{l_mflags} install \
+          DESTDIR=$RPM_BUILD_ROOT \
+          pgconfigdir=%{l_prefix}/bin \
+          pgincludedir=%{l_prefix}/include/postgresql \
+          pgincludeserverdir=%{l_prefix}/include/postgresql/libpq \
+          pglibdir=%{l_prefix}/lib/postgresql \
+          pgpkglibdir=%{l_prefix}/lib/postgresql \
+          pgsharedir=%{l_prefix}/share/postgresql
+      rm -f $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/slony1*v7[34].sql
+      rm -f $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/xxid.v73.sql
+      mv $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/xxid.v74.sql \
+         $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/xxid.sql
+      ( echo "#   Slony-1 configuration for replication engine slon(1)"
+        echo "SLON_CLUSTER_NAME=\"example\""
+        echo "SLON_CONNECT_DBNAME=\"example\""
+        echo "SLON_CONNECT_USER=\"postgresql\""
+        echo "SLON_CONNECT_PASS=\"postgresql\""
+        echo "SLON_CONNECT_HOST=\"localhost\""
+        echo "SLON_SYNC_INTERVAL=\"10000\""
+        echo "SLON_SYNC_TIMEOUT=\"60000\""
+        echo "SLON_SYNC_GROUPSIZE=\"6\""
+        echo "SLON_SYNC_LOGLEVEL=\"1\""
+      ) >$RPM_BUILD_ROOT%{l_prefix}/etc/postgresql/slony1.conf
+    ) || exit $?
+%endif
+
+    #   post-adjust pgcluster configuration filenames
+%if "%{with_pgcluster}" == "yes"
+    cp $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/pgreplicate.conf.sample \
+       $RPM_BUILD_ROOT%{l_prefix}/etc/postgresql/pgreplicate.conf
+%endif
+
+    #   install MySQL compatibility layer
+%if "%{with_mysqlcompat}" == "yes"
+    %{l_shtool} mkdir -f -p -m 755 \
+        $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/mysqlcompat
+    %{l_shtool} install -c -m 644 \
+        mysqlcompat-%{V_mysqlcompat}/README \
+        mysqlcompat-%{V_mysqlcompat}/*.sql \
+        $RPM_BUILD_ROOT%{l_prefix}/share/postgresql/mysqlcompat/
+%endif
+
+    #   install run-command script
+    %{l_shtool} mkdir -f -p -m 755 \
+        $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d
+    %{l_shtool} install -c -m 755 %{l_value -s -a} \
+        %{SOURCE rc.postgresql} \
+        $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
+
+    #   optionally strip down to client-only installation
+%if "%{with_server}" != "yes"
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/pg_[a-bd-z]*
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/pg_c[a-np-z]*
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/pg_controldata
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/post*
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/man/man1/pg_[a-bd-z]*
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/man/man1/pg_c[a-np-z]*
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/man/man1/pg_controldata.1
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/man/man1/post*
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/include/postgresql/server
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/lib/postgresql
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/share/postgresql
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/var/postgresql
+%endif
+
+    #   determine installation files
+    %{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
+%if "%{with_server}" == "yes"
+        %{l_files_std} `cat perl-openpkg-files` \
+%if "%{with_slony1}" == "yes" || "%{with_pgcluster}" == "yes"
+        '%config %{l_prefix}/etc/postgresql/*' \
+%endif
+        '%attr(700,%{l_rusr},%{l_rgrp}) %dir %{l_prefix}/var/postgresql/db' \
+        '%attr(755,%{l_rusr},%{l_rgrp}) %dir %{l_prefix}/var/postgresql/run'
+%else
+        %{l_files_std} `cat perl-openpkg-files`
+%endif
+
+%files -f files
+
+%clean
+    rm -rf $RPM_BUILD_ROOT
+
+%pre
+%if "%{with_server}" == "yes"
+    #   before upgrade, check migration dump, save status and stop service
+    [ $1 -eq 2 ] || exit 0
+    if [ -f $RPM_INSTALL_PREFIX/var/postgresql/db/PG_VERSION -a \
+         -f $RPM_INSTALL_PREFIX/bin/pg_migrate ]; then
+        #   database migration dumping hint
+        v_old_all=`cat $RPM_INSTALL_PREFIX/var/postgresql/db/PG_VERSION`
+        v_old_maj=`echo "$v_old_all" | sed -e 's/^\([0-9]*\.[0-9]*\).*/\1/'`
+        v_new_all="%{V_postgresql_base}b%{V_postgresql_beta}"
+        v_new_maj=`echo "$v_new_all" | sed -e 's/^\([0-9]*\.[0-9]*\).*/\1/'`
+        if [ ".$v_old_maj" != ".$v_new_maj" ]; then
+           if [ ! -f $RPM_INSTALL_PREFIX/var/postgresql/db.dump.sql.bz2 -a ".$RPM_POSTGRESQL_MIGRATE" != .ignore ]; then
+                ( echo "You are upgrading from PostgreSQL $v_old_all to PostgresSQL $v_new_all,"
+                  echo "which is a major version change. We expect a database incompatibility,"
+                  echo "so we strongly recommend that you backup your existing database"
+                  echo "($RPM_INSTALL_PREFIX/var/postgresql/db/) first by running:"
+                  echo "    \$ $RPM_INSTALL_PREFIX/bin/pg_migrate dump"
+                  echo "If this fails for some reasons, try to dump your data manually:"
+                  echo "    \$ $RPM_INSTALL_PREFIX/bin/pg_dumpall -U postgresql -o | \\ "
+                  echo "      $RPM_INSTALL_PREFIX/lib/openpkg/bzip2 -9 \\ "
+                  echo "      >$RPM_INSTALL_PREFIX/var/postgresql/db.dump.sql.bz2"
+                  echo "Alternatively, if you want to force this package to be installed without"
+                  echo "performing a database dump, run the following command before upgrading:"
+                  echo "    \$ RPM_POSTGRESQL_MIGRATE=ignore; export RPM_POSTGRESQL_MIGRATE"
+                ) | %{l_rpmtool} msg -b -t error
+                exit 1
+            fi
+        fi
+    fi
+    eval `%{l_rc} postgresql status 2>/dev/null | tee %{l_tmpfile}`
+    %{l_rc} postgresql stop 2>/dev/null
+    exit 0
+%endif
+
+%post
+%if "%{with_server}" == "yes"
+    if [ $1 -eq 1 ]; then
+        #   create initial database
+%if "%{with_compat}" == "yes"
+        l_pguser="postgres"
+        l_pgpass="postgres"
+%else
+        l_pguser="postgresql"
+        l_pgpass="postgresql"
+%endif
+        su - %{l_rusr} -c \
+            "LC_CTYPE=C; export LC_CTYPE; umask 022; \
+            rm -rf $RPM_INSTALL_PREFIX/var/postgresql/db/*; \
+            echo $l_pgpass >$RPM_INSTALL_PREFIX/var/postgresql/run/pw; \
+            $RPM_INSTALL_PREFIX/bin/pg_initdb \
+                -U $l_pguser --pwfile=$RPM_INSTALL_PREFIX/var/postgresql/run/pw \
+                -D $RPM_INSTALL_PREFIX/var/postgresql/db; \
+            rm -f $RPM_INSTALL_PREFIX/var/postgresql/run/pw" 2>&1 |\
+        $RPM_INSTALL_PREFIX/lib/openpkg/shtool prop \
+            -p "Creating initial PostgreSQL DB in $RPM_INSTALL_PREFIX/var/postgresql/db"
+
+        #   adjust initial authentication configuration
+        cp $RPM_INSTALL_PREFIX/var/postgresql/db/pg_hba.conf \
+           $RPM_INSTALL_PREFIX/var/postgresql/db/pg_hba.conf.old
+        ( cat $RPM_INSTALL_PREFIX/var/postgresql/db/pg_hba.conf.old |\
+          sed -e 's;^\([^#]\);# \1;' -e 's;^$;#;'
+          echo ""
+          echo "#   OpenPKG PostgreSQL default access policy"
+          echo "local all all                           md5"
+          echo "host  all all 127.0.0.1 255.255.255.255 md5"
+          echo ""
+        ) >$RPM_INSTALL_PREFIX/var/postgresql/db/pg_hba.conf
+        rm -f $RPM_INSTALL_PREFIX/var/postgresql/db/pg_hba.conf.old
+
+        #   display information about next steps
+        ( echo "An initial PostgreSQL DB was created with the two standard"
+          echo "databases 'template0' and 'template1'. The owner of both"
+          echo "is the DB user '$l_pguser'. Its initial password is '$l_pgpass'."
+          echo "After starting PostgreSQL with"
+          echo "    \$ $RPM_INSTALL_PREFIX/etc/rc postgresql start"
+          echo "you should immediately change this with the following command:"
+          echo "    \$ $RPM_INSTALL_PREFIX/bin/psql -U $l_pguser -d template1 \\"
+          echo "      -c \"ALTER USER $l_pguser WITH PASSWORD '<new-password>'\""
+          echo "Then you usually create a database for a user <user> (assuming that"
+          echo "his home directory is /u/<user>) with password <password> under"
+          echo "path /u/<user>/rdbms with the commands:"
+          echo "    \$ mkdir /u/<user>/rdbms"
+          echo "    \$ chmod 700 /u/<user>/rdbms"
+          echo "    \$ chown %{l_rusr}:%{l_rgrp} /u/<user>/rdbms"
+          echo "    \$ $RPM_INSTALL_PREFIX/bin/psql -U $l_pguser -d template1"
+          echo "    template1=> CREATE ROLE <user> LOGIN"
+          echo "                ENCRYPTED PASSWORD '<password>'"
+          echo "                NOCREATEDB NOCREATEROLE;"
+          echo "    template1=> CREATE TABLESPACE <user> OWNER <user>"
+          echo "                LOCATION '/u/<user>/rdbms';"
+          echo "    template1=> CREATE DATABASE <user> OWNER <user>"
+          echo "                TABLESPACE <user>;"
+          echo "    \$ echo 'localhost:*:<user>:<user>:<password>' >>/u/<user>/.pgpass"
+          echo "    \$ chmod 600 <user> /u/<user>/.pgpass; chown <user> /u/<user>/.pgpass"
+          echo "After this the user <user> will be able to connect to his RDBMS with:"
+          echo "    \$ psql"
+        ) | %{l_rpmtool} msg -b -t notice
+
+        #   optionally link into unixODBC
+%if "%{with_odbc}" == "yes"
+        ( echo "[PostgreSQL]"
+          echo "Description     = PostgreSQL ODBC driver"
+          echo "Driver          = $RPM_INSTALL_PREFIX/lib/psqlodbc.so"
+          echo "Threading       = 2"
+        ) | $RPM_INSTALL_PREFIX/bin/odbcinst -i -d -r
+%endif
+    fi
+    if [ $1 -eq 2 ]; then
+        #   after upgrade, restore status
+        { eval `cat %{l_tmpfile}`; rm -f %{l_tmpfile}; true; } >/dev/null 2>&1
+        [ ".$postgresql_active" = .yes ] && %{l_rc} postgresql start
+        if [ -f $RPM_INSTALL_PREFIX/var/postgresql/db/PG_VERSION -a ".$PG_MIGRATE" != .ignore ]; then
+            #   database migration restoring hint
+            v_old_all=`cat $RPM_INSTALL_PREFIX/var/postgresql/db/PG_VERSION`
+            v_old_maj=`echo "$v_old_all" | sed -e 's/^\([0-9]*\.[0-9]*\).*/\1/'`
+            v_new_all="%{V_postgresql_base}b%{V_postgresql_beta}"
+            v_new_maj=`echo "$v_new_all" | sed -e 's/^\([0-9]*\.[0-9]*\).*/\1/'`
+            if [ ".$v_old_maj" != ".$v_new_maj" ]; then
+                ( echo "You upgraded from PostgreSQL $v_old_all to PostgresSQL $v_new_all,"
+                  echo "which is a major version upgrade. We expect a database incompatibility,"
+                  echo "so we strongly recommend you to recreate the existing database under"
+                  echo "$RPM_INSTALL_PREFIX/var/postgresql/db/ by running the following command:"
+                  echo "    \$ $RPM_INSTALL_PREFIX/bin/pg_migrate restore"
+                  echo "If this fails for some reasons, try to restore your data manually:"
+                  echo "    \$ $RPM_INSTALL_PREFIX/lib/openpkg/bzip2 -d -c \\ "
+                  echo "      $RPM_INSTALL_PREFIX/var/postgresql/db.dump.sql.bz2 | \\ "
+                  echo "      $RPM_INSTALL_PREFIX/bin/psql -U postgresql -d template1"
+                ) | %{l_rpmtool} msg -b -t warn
+            fi
+        fi
+    fi
+    exit 0
+%endif
+
+%preun
+%if "%{with_server}" == "yes"
+    #   before erase, stop service and remove log files
+    [ $1 -eq 0 ] || exit 0
+    %{l_rc} postgresql stop 2>/dev/null
+    rm -f $RPM_INSTALL_PREFIX/var/postgresql/run/* >/dev/null 2>&1 || true
+    exit 0
+%endif
+

+ 108 - 0
postgresql82/rc.postgresql

@@ -0,0 +1,108 @@
+#!@l_prefix@/bin/openpkg rc
+##
+##  rc.postgresql -- Run-Commands
+##
+
+%config
+    postgresql_enable="$openpkg_rc_def"
+    postgresql_flags=""
+    postgresql_datadir="@l_prefix@/var/postgresql/db"
+    postgresql_rundir="@l_prefix@/var/postgresql/run"
+    postgresql_shut_mode="fast"
+    postgresql_socket_inet="127.0.0.1"
+    postgresql_socket_unix="@l_prefix@/var/postgresql/run/"
+    postgresql_log_prolog="true"
+    postgresql_log_epilog="true"
+    postgresql_log_numfiles="10"
+    postgresql_log_minsize="1M"
+    postgresql_log_complevel="9"
+    postgresql_slony1="no"
+
+%common
+    postgresql_opts="-h $postgresql_socket_inet -k $postgresql_socket_unix"
+    postgresql_opts="$postgresql_opts $postgresql_flags"
+    postgresql_logfile="$postgresql_rundir/postgresql.log"
+    postgresql_pidfile="$postgresql_datadir/postgresql.pid"
+    postgresql_slony1_pidfile="$postgresql_rundir/slon.pid"
+    postgresql_slony1_start () {
+        ( . @l_prefix@/etc/postgresql/slony1.conf
+          nohup @l_prefix@/bin/slon \
+              -d "$SLON_SYNC_LOGLEVEL" -g "$SLON_SYNC_GROUPSIZE" \
+              -s "$SLON_SYNC_INTERVAL" -t "$SLON_SYNC_TIMEOUT" \
+              "$SLON_CLUSTER_NAME" \
+              user="$SLON_CONNECT_USER" password="$SLON_CONNECT_PASS" \
+              dbname="$SLON_CONNECT_DBNAME" host="$SLON_CONNECT_HOST"
+              </dev/null >/dev/null 2>&1 &
+          echo $! >$postgresql_slony1_pidfile
+        ) >/dev/null 2>&1
+    }
+    postgresql_slony1_stop () {
+        if [ -f $postgresql_slony1_pidfile ]; then
+            kill -TERM `cat $postgresql_slony1_pidfile`
+            rm -f $postgresql_slony1_pidfile
+        fi
+    }
+    postgresql_ctl () {
+        if [ -s $postgresql_pidfile ]; then
+            kill -0 `head -1 $postgresql_pidfile` >/dev/null 2>&1
+            if [ $? -ne 0 ]; then
+                rm -f $postgresql_pidfile    >/dev/null 2>&1 || true
+                rm -f $postgresql_rundir/.s* >/dev/null 2>&1 || true
+            fi
+        fi
+        cmd="$1"; shift
+        @l_prefix@/bin/pg_ctl $cmd \
+            -l $postgresql_logfile \
+            -D $postgresql_datadir \
+            ${1+"$@"}
+    }
+
+%status -u @l_rusr@ -o
+    postgresql_usable="unknown"
+    postgresql_active="no"
+    rcService postgresql enable yes && \
+        postgresql_ctl status >/dev/null && \
+        postgresql_active="yes"
+    echo "postgresql_enable=\"$postgresql_enable\""
+    echo "postgresql_usable=\"$postgresql_usable\""
+    echo "postgresql_active=\"$postgresql_active\""
+
+%start -p 400 -u @l_rusr@
+    rcService postgresql enable yes || exit 0
+    rcService postgresql active yes && exit 0
+    postgresql_ctl start -o "$postgresql_opts"
+    if rcVarIsYes postgresql_slony1; then
+        postgresql_slony1_start
+    fi
+
+%stop -p 600 -u @l_rusr@
+    rcService postgresql enable yes || exit 0
+    rcService postgresql active no  && exit 0
+    postgresql_ctl stop -m "$postgresql_shut_mode"
+    if rcVarIsYes postgresql_slony1; then
+        postgresql_slony1_stop
+    fi
+
+%restart -p 400 -u @l_rusr@
+    rcService postgresql enable yes || exit 0
+    rcService postgresql active no  && exit 0
+    postgresql_ctl restart -o "$postgresql_opts" -m "$postgresql_shut_mode"
+    if rcVarIsYes postgresql_slony1; then
+        postgresql_slony1_stop
+        postgresql_slony1_start
+    fi
+
+%reload -p 400 -u @l_rusr@
+    rcService postgresql enable yes || exit 0
+    rcService postgresql active no  && exit 0
+    postgresql_ctl reload
+
+%daily -u @l_rusr@
+    rcService postgresql enable yes || exit 0
+    shtool rotate -f \
+        -n ${postgresql_log_numfiles} -s ${postgresql_log_minsize} -d -c \
+        -z ${postgresql_log_complevel} -m 600 -o @l_rusr@ -g @l_rgrp@ \
+        -P "$postgresql_log_prolog" \
+        -E "$postgresql_log_epilog" \
+        $postgresql_logfile
+