[dev-db/postgresql] add from pr with improved init script
This commit is contained in:
		
							
								
								
									
										1
									
								
								dev-db/postgresql/Manifest
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								dev-db/postgresql/Manifest
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
DIST postgresql-15.3.tar.bz2 22819107 BLAKE2B 4d2e79a9cb21faf47be963e31b1a8ccc9ae205b5836dfbf8ea426229a31dc63f40cd0280108abfa0553affe692c42137f7ad4e3bd1d269298689fee82c5dbb89 SHA512 cac97edeb40df1e8f2162f401b465751132929d7249495ef001e950645a2db46343bd732e7bd6504a7f795e25aea66724f2f4ab0065e3d9331b36db4b3a3bec6
 | 
			
		||||
							
								
								
									
										146
									
								
								dev-db/postgresql/files/postgresql-15_beta3-no-server.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								dev-db/postgresql/files/postgresql-15_beta3-no-server.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,146 @@
 | 
			
		||||
--- a/contrib/Makefile
 | 
			
		||||
+++ b/contrib/Makefile
 | 
			
		||||
@@ -5,59 +5,9 @@
 | 
			
		||||
 include $(top_builddir)/src/Makefile.global
 | 
			
		||||
 
 | 
			
		||||
 SUBDIRS = \
 | 
			
		||||
-		adminpack	\
 | 
			
		||||
-		amcheck		\
 | 
			
		||||
-		auth_delay	\
 | 
			
		||||
-		auto_explain	\
 | 
			
		||||
-		basic_archive	\
 | 
			
		||||
-		basebackup_to_shell	\
 | 
			
		||||
-		bloom		\
 | 
			
		||||
-		btree_gin	\
 | 
			
		||||
-		btree_gist	\
 | 
			
		||||
-		citext		\
 | 
			
		||||
-		cube		\
 | 
			
		||||
-		dblink		\
 | 
			
		||||
-		dict_int	\
 | 
			
		||||
-		dict_xsyn	\
 | 
			
		||||
-		earthdistance	\
 | 
			
		||||
-		file_fdw	\
 | 
			
		||||
-		fuzzystrmatch	\
 | 
			
		||||
-		hstore		\
 | 
			
		||||
-		intagg		\
 | 
			
		||||
-		intarray	\
 | 
			
		||||
-		isn		\
 | 
			
		||||
-		lo		\
 | 
			
		||||
-		ltree		\
 | 
			
		||||
 		oid2name	\
 | 
			
		||||
-		old_snapshot	\
 | 
			
		||||
-		pageinspect	\
 | 
			
		||||
-		passwordcheck	\
 | 
			
		||||
-		pg_buffercache	\
 | 
			
		||||
-		pg_freespacemap \
 | 
			
		||||
-		pg_prewarm	\
 | 
			
		||||
-		pg_stat_statements \
 | 
			
		||||
-		pg_surgery	\
 | 
			
		||||
-		pg_trgm		\
 | 
			
		||||
-		pgrowlocks	\
 | 
			
		||||
-		pgstattuple	\
 | 
			
		||||
-		pg_visibility	\
 | 
			
		||||
-		pg_walinspect	\
 | 
			
		||||
-		postgres_fdw	\
 | 
			
		||||
-		seg		\
 | 
			
		||||
-		spi		\
 | 
			
		||||
-		tablefunc	\
 | 
			
		||||
-		tcn		\
 | 
			
		||||
-		test_decoding	\
 | 
			
		||||
-		tsm_system_rows \
 | 
			
		||||
-		tsm_system_time \
 | 
			
		||||
-		unaccent	\
 | 
			
		||||
 		vacuumlo
 | 
			
		||||
 
 | 
			
		||||
-ifeq ($(with_ssl),openssl)
 | 
			
		||||
-SUBDIRS += pgcrypto sslinfo
 | 
			
		||||
-else
 | 
			
		||||
-ALWAYS_SUBDIRS += pgcrypto sslinfo
 | 
			
		||||
-endif
 | 
			
		||||
 
 | 
			
		||||
 ifneq ($(with_uuid),no)
 | 
			
		||||
 SUBDIRS += uuid-ossp
 | 
			
		||||
--- a/src/backend/Makefile
 | 
			
		||||
+++ b/src/backend/Makefile
 | 
			
		||||
@@ -56,7 +56,7 @@
 | 
			
		||||
 
 | 
			
		||||
 ##########################################################################
 | 
			
		||||
 
 | 
			
		||||
-all: submake-libpgport submake-catalog-headers submake-utils-headers postgres $(POSTGRES_IMP)
 | 
			
		||||
+all: generated-headers
 | 
			
		||||
 
 | 
			
		||||
 ifneq ($(PORTNAME), cygwin)
 | 
			
		||||
 ifneq ($(PORTNAME), win32)
 | 
			
		||||
@@ -194,23 +194,7 @@
 | 
			
		||||
 
 | 
			
		||||
 ##########################################################################
 | 
			
		||||
 
 | 
			
		||||
-install: all installdirs install-bin
 | 
			
		||||
-ifeq ($(PORTNAME), cygwin)
 | 
			
		||||
-ifeq ($(MAKE_DLL), true)
 | 
			
		||||
-	$(INSTALL_DATA) libpostgres.a '$(DESTDIR)$(libdir)/libpostgres.a'
 | 
			
		||||
-endif
 | 
			
		||||
-endif
 | 
			
		||||
-ifeq ($(PORTNAME), win32)
 | 
			
		||||
-ifeq ($(MAKE_DLL), true)
 | 
			
		||||
-	$(INSTALL_DATA) libpostgres.a '$(DESTDIR)$(libdir)/libpostgres.a'
 | 
			
		||||
-endif
 | 
			
		||||
-endif
 | 
			
		||||
-	$(MAKE) -C catalog install-data
 | 
			
		||||
-	$(MAKE) -C tsearch install-data
 | 
			
		||||
-	$(MAKE) -C utils install-data
 | 
			
		||||
-	$(INSTALL_DATA) $(srcdir)/libpq/pg_hba.conf.sample '$(DESTDIR)$(datadir)/pg_hba.conf.sample'
 | 
			
		||||
-	$(INSTALL_DATA) $(srcdir)/libpq/pg_ident.conf.sample '$(DESTDIR)$(datadir)/pg_ident.conf.sample'
 | 
			
		||||
-	$(INSTALL_DATA) $(srcdir)/utils/misc/postgresql.conf.sample '$(DESTDIR)$(datadir)/postgresql.conf.sample'
 | 
			
		||||
+install:
 | 
			
		||||
 
 | 
			
		||||
 ifeq ($(with_llvm), yes)
 | 
			
		||||
 install-bin: install-postgres-bitcode
 | 
			
		||||
--- a/src/bin/Makefile
 | 
			
		||||
+++ b/src/bin/Makefile
 | 
			
		||||
@@ -14,22 +14,8 @@
 | 
			
		||||
 include $(top_builddir)/src/Makefile.global
 | 
			
		||||
 
 | 
			
		||||
 SUBDIRS = \
 | 
			
		||||
-	initdb \
 | 
			
		||||
-	pg_amcheck \
 | 
			
		||||
-	pg_archivecleanup \
 | 
			
		||||
-	pg_basebackup \
 | 
			
		||||
-	pg_checksums \
 | 
			
		||||
 	pg_config \
 | 
			
		||||
-	pg_controldata \
 | 
			
		||||
-	pg_ctl \
 | 
			
		||||
 	pg_dump \
 | 
			
		||||
-	pg_resetwal \
 | 
			
		||||
-	pg_rewind \
 | 
			
		||||
-	pg_test_fsync \
 | 
			
		||||
-	pg_test_timing \
 | 
			
		||||
-	pg_upgrade \
 | 
			
		||||
-	pg_verifybackup \
 | 
			
		||||
-	pg_waldump \
 | 
			
		||||
 	pgbench \
 | 
			
		||||
 	psql \
 | 
			
		||||
 	scripts
 | 
			
		||||
--- a/src/Makefile
 | 
			
		||||
+++ b/src/Makefile
 | 
			
		||||
@@ -17,19 +17,11 @@
 | 
			
		||||
 	port \
 | 
			
		||||
 	timezone \
 | 
			
		||||
 	backend \
 | 
			
		||||
-	backend/utils/mb/conversion_procs \
 | 
			
		||||
-	backend/snowball \
 | 
			
		||||
 	include \
 | 
			
		||||
 	interfaces \
 | 
			
		||||
-	backend/replication/libpqwalreceiver \
 | 
			
		||||
-	backend/replication/pgoutput \
 | 
			
		||||
 	fe_utils \
 | 
			
		||||
 	bin \
 | 
			
		||||
-	pl \
 | 
			
		||||
-	makefiles \
 | 
			
		||||
-	test/regress \
 | 
			
		||||
-	test/isolation \
 | 
			
		||||
-	test/perl
 | 
			
		||||
+	makefiles
 | 
			
		||||
 
 | 
			
		||||
 ifeq ($(with_llvm), yes)
 | 
			
		||||
 SUBDIRS += backend/jit/llvm
 | 
			
		||||
							
								
								
									
										35
									
								
								dev-db/postgresql/files/postgresql-check-db-dir
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								dev-db/postgresql/files/postgresql-check-db-dir
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,35 @@
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
# Copyright 1999-2014 Gentoo Foundation
 | 
			
		||||
# Distributed under the terms of the GNU General Public License v2
 | 
			
		||||
 | 
			
		||||
eerror() {
 | 
			
		||||
    echo "$@" >&2
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
# Check that DATA_DIR has been set
 | 
			
		||||
if [ -z ${DATA_DIR} ] ; then
 | 
			
		||||
    eerror "DATA_DIR not set"
 | 
			
		||||
    exit 1
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# Check that DATA_DIR exists
 | 
			
		||||
if [ ! -d ${DATA_DIR} ] ; then
 | 
			
		||||
    eerror "Directory not found: ${DATA_DIR}"
 | 
			
		||||
    eerror "HINT: Ensure that DATA_DIR points to the right path."
 | 
			
		||||
    eerror "HINT: Or perhaps you need to create the database cluster:"
 | 
			
		||||
    eerror "    emerge --config dev-db/postgresql:@SLOT@"
 | 
			
		||||
    exit 1
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# Check for the existence of PostgreSQL's config files, and set the
 | 
			
		||||
# proper mode and ownership.
 | 
			
		||||
# Only three files should be checked as potentially other files
 | 
			
		||||
# may be in PGDATA that should not be touched.
 | 
			
		||||
for file in postgresql pg_hba pg_ident ; do
 | 
			
		||||
    file="${PGDATA%/}/${file}.conf"
 | 
			
		||||
    if [ ! -f ${file} ] ; then
 | 
			
		||||
        eerror "${file} not found"
 | 
			
		||||
        eerror "HINT: mv ${DATA_DIR%/}/*.conf ${PGDATA}"
 | 
			
		||||
        exit 1
 | 
			
		||||
    fi
 | 
			
		||||
done
 | 
			
		||||
							
								
								
									
										65
									
								
								dev-db/postgresql/files/postgresql.confd-9.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								dev-db/postgresql/files/postgresql.confd-9.3
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,65 @@
 | 
			
		||||
# Comma-separated list of directories that contain a unix
 | 
			
		||||
# socket. Created and controlled by the related initscript. The
 | 
			
		||||
# directories created will be owned root:postgres with mode 1775.
 | 
			
		||||
#
 | 
			
		||||
# /run/postgresql is the default directory.
 | 
			
		||||
PG_SOCKET_DIRECTORIES="/run/postgresql"
 | 
			
		||||
 | 
			
		||||
# Which port and socket to bind PostgreSQL
 | 
			
		||||
PGPORT="5432"
 | 
			
		||||
 | 
			
		||||
# How long to wait for server to start in seconds
 | 
			
		||||
START_TIMEOUT=10
 | 
			
		||||
 | 
			
		||||
# NICE_QUIT ignores new connections and wait for clients to disconnect from
 | 
			
		||||
# server before shutting down. NICE_TIMEOUT in seconds determines how long to
 | 
			
		||||
# wait for this to succeed.
 | 
			
		||||
NICE_TIMEOUT=60
 | 
			
		||||
 | 
			
		||||
# Forcefully disconnect clients from server and shut down. This is performed
 | 
			
		||||
# after NICE_QUIT. Terminated client connections have their open transactions
 | 
			
		||||
# rolled back.
 | 
			
		||||
# Set RUDE_QUIT to "NO" to disable. RUDE_TIMEOUT in seconds.
 | 
			
		||||
RUDE_QUIT="YES"
 | 
			
		||||
RUDE_TIMEOUT=30
 | 
			
		||||
 | 
			
		||||
# If the server still fails to shutdown, you can force it to quit by setting
 | 
			
		||||
# this to YES and a recover-run will execute on the next startup.
 | 
			
		||||
# Set FORCE_QUIT to "YES" to enable. FORCE_TIMEOUT in seconds.
 | 
			
		||||
FORCE_QUIT="NO"
 | 
			
		||||
FORCE_TIMEOUT=2
 | 
			
		||||
 | 
			
		||||
# Extra options to run postmaster with, e.g.:
 | 
			
		||||
# -N is the maximal number of client connections
 | 
			
		||||
# -B is the number of shared buffers and has to be at least 2x the value for -N
 | 
			
		||||
# Please read the man-page to postmaster for more options. Many of these
 | 
			
		||||
# options can be set directly in the configuration file.
 | 
			
		||||
#PGOPTS="-N 512 -B 1024"
 | 
			
		||||
 | 
			
		||||
# Pass extra environment variables. If you have to export environment variables
 | 
			
		||||
# for the database process, this can be done here.
 | 
			
		||||
# Don't forget to escape quotes.
 | 
			
		||||
#PG_EXTRA_ENV="PGPASSFILE=\"/path/to/.pgpass\""
 | 
			
		||||
 | 
			
		||||
##############################################################################
 | 
			
		||||
#
 | 
			
		||||
# The following values should not be arbitrarily changed.
 | 
			
		||||
#
 | 
			
		||||
# `emerge --config dev-db/postgresql:@SLOT@' uses these values to
 | 
			
		||||
# determine where to create the data directory, where to place the
 | 
			
		||||
# configuration files, and any additional options to pass to initdb.
 | 
			
		||||
#
 | 
			
		||||
# The initscript also uses these variables to inform PostgreSQL where to find
 | 
			
		||||
# its data directory and configuration files.
 | 
			
		||||
#
 | 
			
		||||
##############################################################################
 | 
			
		||||
 | 
			
		||||
# Location of configuration files
 | 
			
		||||
PGDATA="/etc/postgresql-@SLOT@/"
 | 
			
		||||
 | 
			
		||||
# Where the data directory is located/to be created
 | 
			
		||||
DATA_DIR="/var/lib/postgresql/@SLOT@/data"
 | 
			
		||||
 | 
			
		||||
# Additional options to pass to initdb.
 | 
			
		||||
# See `man initdb' for available options.
 | 
			
		||||
PG_INITDB_OPTS="--encoding=UTF8"
 | 
			
		||||
							
								
								
									
										204
									
								
								dev-db/postgresql/files/postgresql.init-9.3-r1
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										204
									
								
								dev-db/postgresql/files/postgresql.init-9.3-r1
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,204 @@
 | 
			
		||||
#!/sbin/openrc-run
 | 
			
		||||
# Copyright 1999-2023 Gentoo Foundation
 | 
			
		||||
# Distributed under the terms of the GNU General Public License v2
 | 
			
		||||
 | 
			
		||||
extra_started_commands="reload promote"
 | 
			
		||||
 | 
			
		||||
PG_CTL="/usr/@LIBDIR@/postgresql-@SLOT@/bin/pg_ctl"
 | 
			
		||||
PG_CONTROLDATA="/usr/@LIBDIR@/postgresql-@SLOT@/bin/pg_controldata"
 | 
			
		||||
 | 
			
		||||
description="PostgreSQL @SLOT@ -- the world's most advanced open source database --
 | 
			
		||||
${RC_SERVICE} is a wrapper around pg_ctl with additional administrative checks
 | 
			
		||||
and convenience"
 | 
			
		||||
 | 
			
		||||
# pid is read by fscanf(3) with the first argument which should be integer,
 | 
			
		||||
# so this multiple line pidfile can be used.
 | 
			
		||||
PIDFILE="${DATA_DIR%/}/postmaster.pid"
 | 
			
		||||
 | 
			
		||||
get_config() {
 | 
			
		||||
    [ -f "${PGDATA%/}/postgresql.conf" ] || return 1
 | 
			
		||||
 | 
			
		||||
    eval echo $(sed -e 's:#.*::' "${PGDATA%/}/postgresql.conf" \
 | 
			
		||||
        | awk '$1 == "'$1'" { print ($2 == "=" ? $3 : $2) }')
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
depend() {
 | 
			
		||||
    use net
 | 
			
		||||
    provide postgresql
 | 
			
		||||
 | 
			
		||||
    if [ "$(get_config log_destination)" = "syslog" ] ; then
 | 
			
		||||
        use logger
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
configured_port=${PGPORT}
 | 
			
		||||
config_port() {
 | 
			
		||||
    local port=$(get_config port)
 | 
			
		||||
    [ -z ${port} ] || configured_port=${port}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
checkconfig() {
 | 
			
		||||
    # Check that DATA_DIR has been set
 | 
			
		||||
    if [ -z "${DATA_DIR}" ] ; then
 | 
			
		||||
        eerror "DATA_DIR not set"
 | 
			
		||||
        eerror "HINT: Perhaps you need to update /etc/conf.d/postgresql-@SLOT@"
 | 
			
		||||
        return 1
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    # Check that DATA_DIR exists
 | 
			
		||||
    if [ ! -d "${DATA_DIR}" ] ; then
 | 
			
		||||
        eerror "Directory not found: ${DATA_DIR}"
 | 
			
		||||
        eerror "HINT: Ensure that DATA_DIR points to the right path."
 | 
			
		||||
        eerror "HINT: Or perhaps you need to create the database cluster:"
 | 
			
		||||
        eerror "    emerge --config dev-db/postgresql:@SLOT@"
 | 
			
		||||
        return 1
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    # Check for the existence of PostgreSQL's config files, and set the
 | 
			
		||||
    # proper mode and ownership.
 | 
			
		||||
    # Only three files should be checked as potentially other files
 | 
			
		||||
    # may be in PGDATA that should not be touched.
 | 
			
		||||
    local file
 | 
			
		||||
    for file in postgresql pg_hba pg_ident ; do
 | 
			
		||||
        file="${PGDATA%/}/${file}.conf"
 | 
			
		||||
        if [ -f "${file}" ] ; then
 | 
			
		||||
            checkpath -f -m 0600 -o postgres:postgres "${file}"
 | 
			
		||||
        else
 | 
			
		||||
            eerror "${file} not found"
 | 
			
		||||
            eerror "HINT: mv ${DATA_DIR%/}/*.conf ${PGDATA}"
 | 
			
		||||
            return 1
 | 
			
		||||
        fi
 | 
			
		||||
    done
 | 
			
		||||
 | 
			
		||||
    # Set the proper permission for the socket paths and create it if
 | 
			
		||||
    # it doesn't exist.
 | 
			
		||||
    set -f
 | 
			
		||||
    local IFS=',' s
 | 
			
		||||
    for s in ${PG_SOCKET_DIRECTORIES}; do
 | 
			
		||||
        checkpath -d -m 1775 -o root:postgres "${s}"
 | 
			
		||||
        if [ -e "${s%/}/.s.PGSQL.${configured_port}" ] ; then
 | 
			
		||||
            eerror "Socket conflict."
 | 
			
		||||
            eerror "A server is already listening on:"
 | 
			
		||||
            eerror "    ${s%/}/.s.PGSQL.${configured_port}"
 | 
			
		||||
            eerror "HINT: Change PGPORT to listen on a different socket."
 | 
			
		||||
            return 1
 | 
			
		||||
        fi
 | 
			
		||||
    done
 | 
			
		||||
    set +f
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
start() {
 | 
			
		||||
    config_port
 | 
			
		||||
    checkconfig || return 1
 | 
			
		||||
 | 
			
		||||
    ebegin "Starting PostgreSQL @SLOT@"
 | 
			
		||||
 | 
			
		||||
    rm -f "${DATA_DIR%/}/postmaster.pid"
 | 
			
		||||
 | 
			
		||||
    export PGPORT=${configured_port}
 | 
			
		||||
    eval "${PG_EXTRA_ENV:+export} ${PG_EXTRA_ENV}"
 | 
			
		||||
    start-stop-daemon --start --user postgres:postgres \
 | 
			
		||||
        --pidfile "${PIDFILE}" \
 | 
			
		||||
        --exec "${PG_CTL}" -- \
 | 
			
		||||
        start \
 | 
			
		||||
            -s -w -t ${START_TIMEOUT} -l "${DATA_DIR%/}/postmaster.log" \
 | 
			
		||||
            -D "${PGDATA}" \
 | 
			
		||||
            -o "-c data_directory=\"${DATA_DIR}\" \
 | 
			
		||||
                -c unix_socket_directories=\"${PG_SOCKET_DIRECTORIES}\" \
 | 
			
		||||
                ${PGOPTS}"
 | 
			
		||||
 | 
			
		||||
    local retval=$?
 | 
			
		||||
 | 
			
		||||
    if [ ${retval} -ne 0 ] ; then
 | 
			
		||||
        eerror "Check the log for a possible explanation of the above error."
 | 
			
		||||
        eerror "The log may be located at:"
 | 
			
		||||
        eerror "    ${DATA_DIR%/}/postmaster.log"
 | 
			
		||||
        eerror "Or wherever you configured PostgreSQL @SLOT@ to log."
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    eend ${retval}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
stop() {
 | 
			
		||||
    : "${NICE_TIMEOUT:=5}"
 | 
			
		||||
    : "${RUDE_TIMEOUT:=5}"
 | 
			
		||||
    : "${FORCE_TIMEOUT:=5}"
 | 
			
		||||
 | 
			
		||||
    # The SIGTERM is the default signal for s-s-d, and corresponds to the
 | 
			
		||||
    # default stop mode 'smart' of postgres.
 | 
			
		||||
    local retry="SIGTERM/${NICE_TIMEOUT}"
 | 
			
		||||
    local seconds=${NICE_TIMEOUT}
 | 
			
		||||
 | 
			
		||||
    if yesno RUDE_QUIT; then
 | 
			
		||||
      # retry fast stop mode after NICE_TIMEOUT
 | 
			
		||||
      retry="${retry}/SIGINT/${RUDE_TIMEOUT}"
 | 
			
		||||
      seconds=$(( ${seconds} + ${RUDE_TIMEOUT} ))
 | 
			
		||||
    fi
 | 
			
		||||
    if yesno FORCE_QUIT; then
 | 
			
		||||
      # retry immediate stop mode after RUDE_TIMEOUT
 | 
			
		||||
      retry="${retry}/SIGQUIT/${FORCE_TIMEOUT}"
 | 
			
		||||
      seconds=$(( ${seconds} + ${FORCE_TIMEOUT} ))
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    ebegin "Stopping PostgreSQL @SLOT@ (this can take up to ${seconds} seconds)"
 | 
			
		||||
    start-stop-daemon --stop --retry ${retry} --pidfile ${PIDFILE}
 | 
			
		||||
    local retval=$?
 | 
			
		||||
 | 
			
		||||
    if [ ${retval} -eq 0 ] ; then
 | 
			
		||||
        # clean up remaining socket files for the case which postgres has crashed before stopping
 | 
			
		||||
        config_port
 | 
			
		||||
        local IFS=',' s
 | 
			
		||||
        for s in ${PG_SOCKET_DIRECTORIES}; do
 | 
			
		||||
            if ls -1 "${s%/}/.s.PGSQL.${configured_port}"* >/dev/null 2>&1; then
 | 
			
		||||
                ewarn "cleaning up remaining socket files in '$s'"
 | 
			
		||||
                rm -vf "${s%/}/.s.PGSQL.${configured_port}"*
 | 
			
		||||
            fi
 | 
			
		||||
        done
 | 
			
		||||
    fi
 | 
			
		||||
    eend ${retval}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
status() {
 | 
			
		||||
    default_status
 | 
			
		||||
    local retval=$?
 | 
			
		||||
    local postopts_file="${DATA_DIR%/}/postmaster.opts"
 | 
			
		||||
    if [ $retval -eq 0 -a -r "${postopts_file}" ] ; then
 | 
			
		||||
        einfo "opts: $(cat ${postopts_file})"
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
description_reload="Simply sends the postgres process a SIGHUP signal, causing
 | 
			
		||||
           it to reread its configuration files (postgresql.conf, pg_hba.conf,
 | 
			
		||||
           etc.). This allows changing of configuration-file options that do not
 | 
			
		||||
           require a complete restart to take effect."
 | 
			
		||||
reload() {
 | 
			
		||||
    ebegin "Reloading PostgreSQL @SLOT@ configuration"
 | 
			
		||||
    start-stop-daemon \
 | 
			
		||||
        --signal SIGHUP \
 | 
			
		||||
        --user postgres:postgres \
 | 
			
		||||
        --pidfile "${PIDFILE}"
 | 
			
		||||
    eend $?
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
description_promote="If the server is in standby, it is commanded to exit
 | 
			
		||||
            recovery and begin read-write operations."
 | 
			
		||||
promote() {
 | 
			
		||||
    ebegin "Promoting PostgreSQL @SLOT@"
 | 
			
		||||
    local retval=1
 | 
			
		||||
    if "${PG_CONTROLDATA}" -D "${DATA_DIR}" 2>/dev/null \
 | 
			
		||||
        | grep 'in archive recovery' >/dev/null 2>&1; then
 | 
			
		||||
        local promotefile="${DATA_DIR%/}/promote"
 | 
			
		||||
        checkpath -q -f -m 644 -o postgres:postgres "${promotefile}" && \
 | 
			
		||||
            start-stop-daemon \
 | 
			
		||||
                --signal SIGUSR1 \
 | 
			
		||||
                --user postgres:postgres \
 | 
			
		||||
                --pidfile "${PIDFILE}"
 | 
			
		||||
        retval=$?
 | 
			
		||||
        if [ ${retval} -ne 0 ] ; then
 | 
			
		||||
            rm -f "${promotefile}"
 | 
			
		||||
        fi
 | 
			
		||||
    else
 | 
			
		||||
        eerror "server is not in standby mode"
 | 
			
		||||
    fi
 | 
			
		||||
    eend ${retval}
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										52
									
								
								dev-db/postgresql/files/postgresql.service-9.6-r1
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								dev-db/postgresql/files/postgresql.service-9.6-r1
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,52 @@
 | 
			
		||||
# It's not recommended to modify this file in-place, because it will be
 | 
			
		||||
# overwritten during package upgrades. If you want to customize, the
 | 
			
		||||
# best way is to create file
 | 
			
		||||
# "/etc/systemd/system/postgresql-@SLOT@.service.d/*.conf"
 | 
			
		||||
# containing your changes
 | 
			
		||||
 | 
			
		||||
# For example, if you want to change the server's port number to 5433,
 | 
			
		||||
# create a file named
 | 
			
		||||
# "/etc/systemd/system/postgresql-@SLOT@.service.d/port.conf"
 | 
			
		||||
# containing:
 | 
			
		||||
#       [Service]
 | 
			
		||||
#       Environment=PGPORT=5433
 | 
			
		||||
# This will override the setting appearing below.
 | 
			
		||||
 | 
			
		||||
[Unit]
 | 
			
		||||
Description=PostgreSQL database server
 | 
			
		||||
After=network.target
 | 
			
		||||
 | 
			
		||||
[Service]
 | 
			
		||||
Type=notify
 | 
			
		||||
 | 
			
		||||
User=postgres
 | 
			
		||||
Group=postgres
 | 
			
		||||
 | 
			
		||||
# Port number for server to listen on
 | 
			
		||||
Environment=PGPORT=5432
 | 
			
		||||
 | 
			
		||||
# Location of configuration files
 | 
			
		||||
Environment=PGDATA=/etc/postgresql-@SLOT@
 | 
			
		||||
 | 
			
		||||
# Where the data directory is located
 | 
			
		||||
Environment=DATA_DIR=/var/lib/postgresql/@SLOT@/data
 | 
			
		||||
 | 
			
		||||
# Where to send early-startup messages from the server (before the logging
 | 
			
		||||
# options of postgresql.conf take effect)
 | 
			
		||||
# This is normally controlled by the global default set by systemd
 | 
			
		||||
# StandardOutput=syslog
 | 
			
		||||
 | 
			
		||||
ExecStartPre=/usr/bin/postgresql-@SLOT@-check-db-dir
 | 
			
		||||
ExecStart=/usr/@LIBDIR@/postgresql-@SLOT@/bin/postgres -p ${PGPORT} -D ${DATA_DIR}
 | 
			
		||||
ExecReload=/bin/kill -HUP $MAINPID
 | 
			
		||||
KillMode=mixed
 | 
			
		||||
KillSignal=SIGINT
 | 
			
		||||
 | 
			
		||||
# Give a reasonable amount of time for the server to start up/shut down
 | 
			
		||||
TimeoutSec=300
 | 
			
		||||
 | 
			
		||||
# Disable OOM kill on the postmaster
 | 
			
		||||
OOMScoreAdjust=-1000
 | 
			
		||||
 | 
			
		||||
[Install]
 | 
			
		||||
WantedBy=multi-user.target
 | 
			
		||||
							
								
								
									
										1
									
								
								dev-db/postgresql/files/postgresql.tmpfiles
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								dev-db/postgresql/files/postgresql.tmpfiles
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
d /run/postgresql 1775 root postgres -
 | 
			
		||||
							
								
								
									
										24
									
								
								dev-db/postgresql/metadata.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								dev-db/postgresql/metadata.xml
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,24 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
 | 
			
		||||
<pkgmetadata>
 | 
			
		||||
	<maintainer type="project">
 | 
			
		||||
		<email>pgsql-bugs@gentoo.org</email>
 | 
			
		||||
		<name>PostgreSQL and Related Package Development</name>
 | 
			
		||||
	</maintainer>
 | 
			
		||||
	<use>
 | 
			
		||||
		<flag name="llvm">
 | 
			
		||||
			Add support for llvm JIT engine
 | 
			
		||||
		</flag>
 | 
			
		||||
		<flag name="server">
 | 
			
		||||
			Disable to build and install the clients and libraries
 | 
			
		||||
			only.
 | 
			
		||||
		</flag>
 | 
			
		||||
		<flag name="uuid">
 | 
			
		||||
			Enable server side UUID generation (via
 | 
			
		||||
			<pkg>dev-libs/ossp-uuid</pkg>).
 | 
			
		||||
		</flag>
 | 
			
		||||
	</use>
 | 
			
		||||
	<upstream>
 | 
			
		||||
		<remote-id type="github">postgres/postgres</remote-id>
 | 
			
		||||
	</upstream>
 | 
			
		||||
</pkgmetadata>
 | 
			
		||||
							
								
								
									
										467
									
								
								dev-db/postgresql/postgresql-15.3.ebuild
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										467
									
								
								dev-db/postgresql/postgresql-15.3.ebuild
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,467 @@
 | 
			
		||||
# Copyright 1999-2023 Gentoo Authors
 | 
			
		||||
# Distributed under the terms of the GNU General Public License v2
 | 
			
		||||
 | 
			
		||||
EAPI=8
 | 
			
		||||
 | 
			
		||||
PYTHON_COMPAT=( python3_{9,10,11} )
 | 
			
		||||
LLVM_MAX_SLOT=15
 | 
			
		||||
 | 
			
		||||
inherit flag-o-matic linux-info llvm pam python-single-r1 systemd tmpfiles
 | 
			
		||||
 | 
			
		||||
KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ia64 ~loong ~mips ppc ppc64 ~riscv ~s390 sparc x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
 | 
			
		||||
 | 
			
		||||
SLOT=$(ver_cut 1)
 | 
			
		||||
 | 
			
		||||
MY_PV=${PV/_/}
 | 
			
		||||
S="${WORKDIR}/${PN}-${MY_PV}"
 | 
			
		||||
 | 
			
		||||
SRC_URI="https://ftp.postgresql.org/pub/source/v${MY_PV}/postgresql-${MY_PV}.tar.bz2"
 | 
			
		||||
 | 
			
		||||
LICENSE="POSTGRESQL GPL-2"
 | 
			
		||||
DESCRIPTION="PostgreSQL RDBMS"
 | 
			
		||||
HOMEPAGE="https://www.postgresql.org/"
 | 
			
		||||
 | 
			
		||||
IUSE="debug doc icu kerberos ldap llvm lz4 nls pam
 | 
			
		||||
	  perl python +readline selinux +server systemd ssl static-libs tcl
 | 
			
		||||
	  threads uuid xml zlib zstd"
 | 
			
		||||
 | 
			
		||||
REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )"
 | 
			
		||||
 | 
			
		||||
CDEPEND="
 | 
			
		||||
>=app-eselect/eselect-postgresql-2.0
 | 
			
		||||
acct-group/postgres
 | 
			
		||||
acct-user/postgres
 | 
			
		||||
sys-apps/less
 | 
			
		||||
virtual/libintl
 | 
			
		||||
icu? ( dev-libs/icu:= )
 | 
			
		||||
kerberos? ( virtual/krb5 )
 | 
			
		||||
ldap? ( net-nds/openldap:= )
 | 
			
		||||
llvm? (
 | 
			
		||||
	<sys-devel/llvm-16:=
 | 
			
		||||
	<sys-devel/clang-16:=
 | 
			
		||||
)
 | 
			
		||||
lz4? ( app-arch/lz4 )
 | 
			
		||||
pam? ( sys-libs/pam )
 | 
			
		||||
perl? ( >=dev-lang/perl-5.8:= )
 | 
			
		||||
python? ( ${PYTHON_DEPS} )
 | 
			
		||||
readline? ( sys-libs/readline:0= )
 | 
			
		||||
server? ( systemd? ( sys-apps/systemd ) )
 | 
			
		||||
ssl? ( >=dev-libs/openssl-0.9.6-r1:0= )
 | 
			
		||||
tcl? ( >=dev-lang/tcl-8:0= )
 | 
			
		||||
xml? ( dev-libs/libxml2 dev-libs/libxslt )
 | 
			
		||||
zlib? ( sys-libs/zlib )
 | 
			
		||||
zstd? ( app-arch/zstd )
 | 
			
		||||
"
 | 
			
		||||
 | 
			
		||||
# uuid flags -- depend on sys-apps/util-linux for Linux libcs, or if no
 | 
			
		||||
# supported libc in use depend on dev-libs/ossp-uuid. For BSD systems,
 | 
			
		||||
# the libc includes UUID functions.
 | 
			
		||||
UTIL_LINUX_LIBC=( elibc_{glibc,musl} )
 | 
			
		||||
 | 
			
		||||
nest_usedep() {
 | 
			
		||||
	local front back
 | 
			
		||||
	while [[ ${#} -gt 1 ]]; do
 | 
			
		||||
		front+="${1}? ( "
 | 
			
		||||
		back+=" )"
 | 
			
		||||
		shift
 | 
			
		||||
	done
 | 
			
		||||
	echo "${front}${1}${back}"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
CDEPEND+="
 | 
			
		||||
uuid? (
 | 
			
		||||
	${UTIL_LINUX_LIBC[@]/%/? ( sys-apps/util-linux )}
 | 
			
		||||
	$(nest_usedep ${UTIL_LINUX_LIBC[@]/#/!} dev-libs/ossp-uuid)
 | 
			
		||||
)"
 | 
			
		||||
 | 
			
		||||
DEPEND="${CDEPEND}
 | 
			
		||||
sys-devel/bison
 | 
			
		||||
sys-devel/flex
 | 
			
		||||
nls? ( sys-devel/gettext )
 | 
			
		||||
xml? ( virtual/pkgconfig )
 | 
			
		||||
"
 | 
			
		||||
 | 
			
		||||
RDEPEND="${CDEPEND}
 | 
			
		||||
selinux? ( sec-policy/selinux-postgresql )
 | 
			
		||||
"
 | 
			
		||||
 | 
			
		||||
pkg_setup() {
 | 
			
		||||
	use llvm && llvm_pkg_setup
 | 
			
		||||
 | 
			
		||||
	use server && CONFIG_CHECK="~SYSVIPC" linux-info_pkg_setup
 | 
			
		||||
 | 
			
		||||
	use python && python-single-r1_pkg_setup
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_prepare() {
 | 
			
		||||
	# Set proper run directory
 | 
			
		||||
	sed "s|\(PGSOCKET_DIR\s\+\)\"/tmp\"|\1\"${EPREFIX}/run/postgresql\"|" \
 | 
			
		||||
		-i src/include/pg_config_manual.h || die
 | 
			
		||||
 | 
			
		||||
	# Rely on $PATH being in the proper order so that the correct
 | 
			
		||||
	# install program is used for modules utilizing PGXS in both
 | 
			
		||||
	# hardened and non-hardened environments. (Bug #528786)
 | 
			
		||||
	sed 's/@install_bin@/install -c/' -i src/Makefile.global.in || die
 | 
			
		||||
 | 
			
		||||
	use server || eapply "${FILESDIR}/${PN}-15_beta3-no-server.patch"
 | 
			
		||||
 | 
			
		||||
	if use pam ; then
 | 
			
		||||
		sed "s/\(#define PGSQL_PAM_SERVICE \"postgresql\)/\1-${SLOT}/" \
 | 
			
		||||
			-i src/backend/libpq/auth.c || \
 | 
			
		||||
			die 'PGSQL_PAM_SERVICE rename failed.'
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	eapply_user
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_configure() {
 | 
			
		||||
	case ${CHOST} in
 | 
			
		||||
		*-darwin*|*-solaris*)
 | 
			
		||||
			use nls && append-libs intl
 | 
			
		||||
			;;
 | 
			
		||||
	esac
 | 
			
		||||
 | 
			
		||||
	export LDFLAGS_SL="${LDFLAGS}"
 | 
			
		||||
	export LDFLAGS_EX="${LDFLAGS}"
 | 
			
		||||
 | 
			
		||||
	local PO="${EPREFIX}"
 | 
			
		||||
 | 
			
		||||
	local i uuid_config=""
 | 
			
		||||
	if use uuid; then
 | 
			
		||||
		for i in ${UTIL_LINUX_LIBC[@]}; do
 | 
			
		||||
			use ${i} && uuid_config="--with-uuid=e2fs"
 | 
			
		||||
		done
 | 
			
		||||
		[[ -z $uuid_config ]] && uuid_config="--with-uuid=ossp"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	local myconf="\
 | 
			
		||||
		--prefix="${PO}/usr/$(get_libdir)/postgresql-${SLOT}" \
 | 
			
		||||
		--datadir="${PO}/usr/share/postgresql-${SLOT}" \
 | 
			
		||||
		--includedir="${PO}/usr/include/postgresql-${SLOT}" \
 | 
			
		||||
		--mandir="${PO}/usr/share/postgresql-${SLOT}/man" \
 | 
			
		||||
		--sysconfdir="${PO}/etc/postgresql-${SLOT}" \
 | 
			
		||||
		--with-system-tzdata="${PO}/usr/share/zoneinfo" \
 | 
			
		||||
		$(use_enable debug) \
 | 
			
		||||
		$(use_enable threads thread-safety) \
 | 
			
		||||
		$(use_with icu) \
 | 
			
		||||
		$(use_with kerberos gssapi) \
 | 
			
		||||
		$(use_with ldap) \
 | 
			
		||||
		$(use_with llvm) \
 | 
			
		||||
		$(use_with lz4) \
 | 
			
		||||
		$(use_with pam) \
 | 
			
		||||
		$(use_with perl) \
 | 
			
		||||
		$(use_with python) \
 | 
			
		||||
		$(use_with readline) \
 | 
			
		||||
		$(use_with ssl openssl) \
 | 
			
		||||
		$(usex server "$(use_with systemd)" '--without-systemd') \
 | 
			
		||||
		$(use_with tcl) \
 | 
			
		||||
		${uuid_config} \
 | 
			
		||||
		$(use_with xml libxml) \
 | 
			
		||||
		$(use_with xml libxslt) \
 | 
			
		||||
		$(use_with zlib) \
 | 
			
		||||
		$(use_with zstd) \
 | 
			
		||||
		$(use_enable nls)"
 | 
			
		||||
	if use alpha; then
 | 
			
		||||
		myconf+=" --disable-spinlocks"
 | 
			
		||||
	else
 | 
			
		||||
		# Should be the default but just in case
 | 
			
		||||
		myconf+=" --enable-spinlocks"
 | 
			
		||||
	fi
 | 
			
		||||
	econf ${myconf}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_compile() {
 | 
			
		||||
	emake
 | 
			
		||||
	emake -C contrib
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_install() {
 | 
			
		||||
	emake DESTDIR="${D}" install
 | 
			
		||||
	emake DESTDIR="${D}" install -C contrib
 | 
			
		||||
 | 
			
		||||
	dodoc README HISTORY
 | 
			
		||||
 | 
			
		||||
	# man pages are already built, but if we have the target make them,
 | 
			
		||||
	# they'll be generated from source before being installed so we
 | 
			
		||||
	# manually install man pages.
 | 
			
		||||
	# We use ${SLOT} instead of doman for postgresql.eselect
 | 
			
		||||
	insinto /usr/share/postgresql-${SLOT}/man/
 | 
			
		||||
	doins -r doc/src/sgml/man{1,3,7}
 | 
			
		||||
	if ! use server; then
 | 
			
		||||
		# Remove man pages for non-existent binaries
 | 
			
		||||
		serverman=(
 | 
			
		||||
			initdb
 | 
			
		||||
			pg_{archivecleanup,controldata,ctl,resetwal,rewind,standby}
 | 
			
		||||
			pg_{test_{fsync,timing},upgrade,waldump}
 | 
			
		||||
			post{gres,master}
 | 
			
		||||
		)
 | 
			
		||||
		for m in ${serverman[@]} ; do
 | 
			
		||||
			rm "${ED}/usr/share/postgresql-${SLOT}/man/man1/${m}.1"
 | 
			
		||||
		done
 | 
			
		||||
	fi
 | 
			
		||||
	docompress /usr/share/postgresql-${SLOT}/man/man{1,3,7}
 | 
			
		||||
 | 
			
		||||
	# Create slot specific man pages
 | 
			
		||||
	local bn f mansec slotted_name
 | 
			
		||||
	for mansec in 1 3 7 ; do
 | 
			
		||||
		local rel_manpath="../../postgresql-${SLOT}/man/man${mansec}"
 | 
			
		||||
 | 
			
		||||
		mkdir -p "${ED}"/usr/share/man/man${mansec} || die "making man dir"
 | 
			
		||||
		pushd "${ED}"/usr/share/man/man${mansec} > /dev/null || die "pushd failed"
 | 
			
		||||
 | 
			
		||||
		for f in "${ED}/usr/share/postgresql-${SLOT}/man/man${mansec}"/* ; do
 | 
			
		||||
			bn=$(basename "${f}")
 | 
			
		||||
			slotted_name=${bn%.${mansec}}${SLOT}.${mansec}
 | 
			
		||||
			case ${bn} in
 | 
			
		||||
				TABLE.7|WITH.7)
 | 
			
		||||
					echo ".so ${rel_manpath}/SELECT.7" > ${slotted_name}
 | 
			
		||||
					;;
 | 
			
		||||
				*)
 | 
			
		||||
					echo ".so ${rel_manpath}/${bn}" > ${slotted_name}
 | 
			
		||||
					;;
 | 
			
		||||
			esac
 | 
			
		||||
		done
 | 
			
		||||
 | 
			
		||||
		popd > /dev/null
 | 
			
		||||
	done
 | 
			
		||||
 | 
			
		||||
	insinto /etc/postgresql-${SLOT}
 | 
			
		||||
	newins src/bin/psql/psqlrc.sample psqlrc
 | 
			
		||||
 | 
			
		||||
	# Don't delete libpg{port,common}.a (Bug #571046). They're always
 | 
			
		||||
	# needed by extensions utilizing PGXS.
 | 
			
		||||
	use static-libs || \
 | 
			
		||||
		find "${ED}" -name '*.a' ! -name libpgport.a ! -name libpgcommon.a \
 | 
			
		||||
			 -delete
 | 
			
		||||
 | 
			
		||||
	# Make slot specific links to programs
 | 
			
		||||
	local f bn
 | 
			
		||||
	for f in $(find "${ED}/usr/$(get_libdir)/postgresql-${SLOT}/bin" \
 | 
			
		||||
					-mindepth 1 -maxdepth 1)
 | 
			
		||||
	do
 | 
			
		||||
		bn=$(basename "${f}")
 | 
			
		||||
		dosym "../$(get_libdir)/postgresql-${SLOT}/bin/${bn}" \
 | 
			
		||||
			  "/usr/bin/${bn}${SLOT/.}"
 | 
			
		||||
	done
 | 
			
		||||
 | 
			
		||||
	if use doc ; then
 | 
			
		||||
		docinto html
 | 
			
		||||
		dodoc doc/src/sgml/html/*
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	if use server; then
 | 
			
		||||
		sed -e "s|@SLOT@|${SLOT}|g" -e "s|@LIBDIR@|$(get_libdir)|g" \
 | 
			
		||||
			"${FILESDIR}/${PN}.confd-9.3" | newconfd - ${PN}-${SLOT}
 | 
			
		||||
 | 
			
		||||
		sed -e "s|@SLOT@|${SLOT}|g" -e "s|@LIBDIR@|$(get_libdir)|g" \
 | 
			
		||||
			"${FILESDIR}/${PN}.init-9.3-r1" | newinitd - ${PN}-${SLOT}
 | 
			
		||||
 | 
			
		||||
		if use systemd; then
 | 
			
		||||
			sed -e "s|@SLOT@|${SLOT}|g" -e "s|@LIBDIR@|$(get_libdir)|g" \
 | 
			
		||||
				"${FILESDIR}/${PN}.service-9.6-r1" | \
 | 
			
		||||
				systemd_newunit - ${PN}-${SLOT}.service
 | 
			
		||||
			newbin "${FILESDIR}"/${PN}-check-db-dir ${PN}-${SLOT}-check-db-dir
 | 
			
		||||
			newtmpfiles "${FILESDIR}"/${PN}.tmpfiles ${PN}-${SLOT}.conf
 | 
			
		||||
		fi
 | 
			
		||||
 | 
			
		||||
		use pam && pamd_mimic system-auth ${PN}-${SLOT} auth account session
 | 
			
		||||
 | 
			
		||||
		if use prefix ; then
 | 
			
		||||
			keepdir /run/postgresql
 | 
			
		||||
			fperms 1775 /run/postgresql
 | 
			
		||||
		fi
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_postinst() {
 | 
			
		||||
	use server && use systemd && tmpfiles_process ${PN}-${SLOT}.conf
 | 
			
		||||
	postgresql-config update
 | 
			
		||||
 | 
			
		||||
	elog "If you need a global psqlrc-file, you can place it in:"
 | 
			
		||||
	elog "    ${EROOT}/etc/postgresql-${SLOT}/"
 | 
			
		||||
 | 
			
		||||
	if use server ; then
 | 
			
		||||
		elog
 | 
			
		||||
		elog "Gentoo specific documentation:"
 | 
			
		||||
		elog "https://wiki.gentoo.org/wiki/PostgreSQL"
 | 
			
		||||
		elog
 | 
			
		||||
		elog "Official documentation:"
 | 
			
		||||
		elog "https://www.postgresql.org/docs/${SLOT}/static/index.html"
 | 
			
		||||
		elog
 | 
			
		||||
		elog "The default location of the Unix-domain socket is:"
 | 
			
		||||
		elog "    ${EROOT}/run/postgresql/"
 | 
			
		||||
		elog
 | 
			
		||||
		elog "Before initializing the database, you may want to edit PG_INITDB_OPTS"
 | 
			
		||||
		elog "so that it contains your preferred locale in:"
 | 
			
		||||
		elog "    ${EROOT}/etc/conf.d/postgresql-${SLOT}"
 | 
			
		||||
		elog
 | 
			
		||||
		elog "Then, execute the following command to setup the initial database"
 | 
			
		||||
		elog "environment:"
 | 
			
		||||
		elog "    emerge --config =${CATEGORY}/${PF}"
 | 
			
		||||
 | 
			
		||||
		if [[ -n ${REPLACING_VERSIONS} ]] ; then
 | 
			
		||||
			ewarn "If your system is using 'pg_stat_statements' and you are running a"
 | 
			
		||||
			ewarn "version of PostgreSQL ${SLOT}, we advise that you execute"
 | 
			
		||||
			ewarn "the following command after upgrading:"
 | 
			
		||||
			ewarn
 | 
			
		||||
			ewarn "ALTER EXTENSION pg_stat_statements UPDATE;"
 | 
			
		||||
		fi
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_prerm() {
 | 
			
		||||
	if use server && [[ -z ${REPLACED_BY_VERSION} ]] ; then
 | 
			
		||||
		ewarn "Have you dumped and/or migrated the ${SLOT} database cluster?"
 | 
			
		||||
		ewarn "\thttps://wiki.gentoo.org/wiki/PostgreSQL/QuickStart#Migrating_PostgreSQL"
 | 
			
		||||
 | 
			
		||||
		ebegin "Resuming removal in 10 seconds (Control-C to cancel)"
 | 
			
		||||
		sleep 10
 | 
			
		||||
		eend 0
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_postrm() {
 | 
			
		||||
	postgresql-config update
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_config() {
 | 
			
		||||
	use server || die "USE flag 'server' not enabled. Nothing to configure."
 | 
			
		||||
 | 
			
		||||
	[[ -f "${EROOT}/etc/conf.d/postgresql-${SLOT}" ]] \
 | 
			
		||||
		&& source "${EROOT}/etc/conf.d/postgresql-${SLOT}"
 | 
			
		||||
	[[ -z "${PGDATA}" ]] && PGDATA="${EROOT}/etc/postgresql-${SLOT}/"
 | 
			
		||||
	[[ -z "${DATA_DIR}" ]] \
 | 
			
		||||
		&& DATA_DIR="${EROOT}/var/lib/postgresql/${SLOT}/data"
 | 
			
		||||
 | 
			
		||||
	# environment.bz2 may not contain the same locale as the current system
 | 
			
		||||
	# locale. Unset and source from the current system locale.
 | 
			
		||||
	if [ -f "${EROOT}/etc/env.d/02locale" ]; then
 | 
			
		||||
		unset LANG
 | 
			
		||||
		unset LC_CTYPE
 | 
			
		||||
		unset LC_NUMERIC
 | 
			
		||||
		unset LC_TIME
 | 
			
		||||
		unset LC_COLLATE
 | 
			
		||||
		unset LC_MONETARY
 | 
			
		||||
		unset LC_MESSAGES
 | 
			
		||||
		unset LC_ALL
 | 
			
		||||
		source "${EROOT}/etc/env.d/02locale"
 | 
			
		||||
		[ -n "${LANG}" ] && export LANG
 | 
			
		||||
		[ -n "${LC_CTYPE}" ] && export LC_CTYPE
 | 
			
		||||
		[ -n "${LC_NUMERIC}" ] && export LC_NUMERIC
 | 
			
		||||
		[ -n "${LC_TIME}" ] && export LC_TIME
 | 
			
		||||
		[ -n "${LC_COLLATE}" ] && export LC_COLLATE
 | 
			
		||||
		[ -n "${LC_MONETARY}" ] && export LC_MONETARY
 | 
			
		||||
		[ -n "${LC_MESSAGES}" ] && export LC_MESSAGES
 | 
			
		||||
		[ -n "${LC_ALL}" ] && export LC_ALL
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	einfo "You can modify the paths and options passed to initdb by editing:"
 | 
			
		||||
	einfo "    ${EROOT}/etc/conf.d/postgresql-${SLOT}"
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "Information on options that can be passed to initdb are found at:"
 | 
			
		||||
	einfo "    https://www.postgresql.org/docs/${SLOT}/static/creating-cluster.html"
 | 
			
		||||
	einfo "    https://www.postgresql.org/docs/${SLOT}/static/app-initdb.html"
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "PG_INITDB_OPTS is currently set to:"
 | 
			
		||||
	if [[ -z "${PG_INITDB_OPTS}" ]] ; then
 | 
			
		||||
		einfo "    (none)"
 | 
			
		||||
	else
 | 
			
		||||
		einfo "    ${PG_INITDB_OPTS}"
 | 
			
		||||
	fi
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "Configuration files will be installed to:"
 | 
			
		||||
	einfo "    ${PGDATA}"
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "The database cluster will be created in:"
 | 
			
		||||
	einfo "    ${DATA_DIR}"
 | 
			
		||||
	einfo
 | 
			
		||||
 | 
			
		||||
	ebegin "Continuing initialization in 5 seconds (Control-C to cancel)"
 | 
			
		||||
	sleep 5
 | 
			
		||||
	eend 0
 | 
			
		||||
 | 
			
		||||
	if [ -n "$(ls -A ${DATA_DIR} 2> /dev/null)" ] ; then
 | 
			
		||||
		eerror "The given directory, '${DATA_DIR}', is not empty."
 | 
			
		||||
		eerror "Modify DATA_DIR to point to an empty directory."
 | 
			
		||||
		die "${DATA_DIR} is not empty."
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	einfo "Creating the data directory ..."
 | 
			
		||||
	if [[ ${EUID} == 0 ]] ; then
 | 
			
		||||
		mkdir -p "$(dirname ${DATA_DIR%/})" || die "Couldn't parent dirs"
 | 
			
		||||
		mkdir -m 0700 "${DATA_DIR%/}" || die "Couldn't make DATA_DIR"
 | 
			
		||||
		chown -h postgres:postgres "${DATA_DIR%/}" || die "Couldn't chown"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	einfo "Initializing the database ..."
 | 
			
		||||
 | 
			
		||||
	if [[ ${EUID} == 0 ]] ; then
 | 
			
		||||
		su - postgres -c "${EROOT}/usr/$(get_libdir)/postgresql-${SLOT}/bin/initdb -D \"${DATA_DIR}\" ${PG_INITDB_OPTS}"
 | 
			
		||||
	else
 | 
			
		||||
		"${EROOT}"/usr/$(get_libdir)/postgresql-${SLOT}/bin/initdb -U postgres -D "${DATA_DIR}" ${PG_INITDB_OPTS}
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	if [[ "${DATA_DIR%/}" != "${PGDATA%/}" ]] ; then
 | 
			
		||||
		mv "${DATA_DIR%/}"/{pg_{hba,ident},postgresql}.conf "${PGDATA}"
 | 
			
		||||
		ln -s "${PGDATA%/}"/{pg_{hba,ident},postgresql}.conf "${DATA_DIR%/}"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	# unix_socket_directory has no effect in postgresql.conf as it's
 | 
			
		||||
	# overridden in the initscript
 | 
			
		||||
	sed '/^#unix_socket_directories/,+1d' -i "${PGDATA%/}"/postgresql.conf
 | 
			
		||||
 | 
			
		||||
	cat <<- EOF >> "${PGDATA%/}"/postgresql.conf
 | 
			
		||||
		# This is here because of https://bugs.gentoo.org/show_bug.cgi?id=518522
 | 
			
		||||
		# On the off-chance that you might need to work with UTF-8 encoded
 | 
			
		||||
		# characters in PL/Perl
 | 
			
		||||
		plperl.on_init = 'use utf8; use re; package utf8; require "utf8_heavy.pl";'
 | 
			
		||||
	EOF
 | 
			
		||||
 | 
			
		||||
	einfo "The autovacuum function, which was in contrib, has been moved to the main"
 | 
			
		||||
	einfo "PostgreSQL functions starting with 8.1, and starting with 8.4 is now enabled"
 | 
			
		||||
	einfo "by default. You can disable it in the cluster's:"
 | 
			
		||||
	einfo "    ${PGDATA%/}/postgresql.conf"
 | 
			
		||||
	einfo
 | 
			
		||||
	if ! use systemd; then
 | 
			
		||||
		einfo "The PostgreSQL server, by default, will log events to:"
 | 
			
		||||
		einfo "    ${DATA_DIR%/}/postmaster.log"
 | 
			
		||||
		einfo
 | 
			
		||||
	fi
 | 
			
		||||
	if use prefix ; then
 | 
			
		||||
		einfo "The location of the configuration files have moved to:"
 | 
			
		||||
		einfo "    ${PGDATA}"
 | 
			
		||||
		einfo "To start the server:"
 | 
			
		||||
		einfo "    pg_ctl start -D ${DATA_DIR} -o '-D ${PGDATA} --data-directory=${DATA_DIR}'"
 | 
			
		||||
		einfo "To stop:"
 | 
			
		||||
		einfo "    pg_ctl stop -D ${DATA_DIR}"
 | 
			
		||||
		einfo
 | 
			
		||||
		einfo "Or move the configuration files back:"
 | 
			
		||||
		einfo "mv ${PGDATA}*.conf ${DATA_DIR}"
 | 
			
		||||
	elif use systemd; then
 | 
			
		||||
		einfo "You should use the 'postgresql-${SLOT}.service' unit to run PostgreSQL"
 | 
			
		||||
		einfo "instead of 'pg_ctl'."
 | 
			
		||||
	else
 | 
			
		||||
		einfo "You should use the '${EROOT}/etc/init.d/postgresql-${SLOT}' script to run PostgreSQL"
 | 
			
		||||
		einfo "instead of 'pg_ctl'."
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_test() {
 | 
			
		||||
	if use server && [[ ${UID} -ne 0 ]] ; then
 | 
			
		||||
		# Some ICU tests fail if LC_CTYPE and LC_COLLATE aren't the same. We set
 | 
			
		||||
		# LC_CTYPE to be equal to LC_COLLATE since LC_COLLATE is set by Portage.
 | 
			
		||||
		local old_ctype=${LC_CTYPE}
 | 
			
		||||
		export LC_CTYPE=${LC_COLLATE}
 | 
			
		||||
		emake check
 | 
			
		||||
		export LC_CTYPE=${old_ctype}
 | 
			
		||||
		einfo "If you think other tests besides the regression tests are necessary, please"
 | 
			
		||||
		einfo "submit a bug including a patch for this ebuild to enable them."
 | 
			
		||||
	else
 | 
			
		||||
		use server || \
 | 
			
		||||
			ewarn 'Tests cannot be run without the "server" use flag enabled.'
 | 
			
		||||
		[[ ${UID} -eq 0 ]] || \
 | 
			
		||||
			ewarn 'Tests cannot be run as root. Enable "userpriv" in FEATURES.'
 | 
			
		||||
 | 
			
		||||
		ewarn 'Skipping.'
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										472
									
								
								dev-db/postgresql/postgresql-9999.ebuild
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										472
									
								
								dev-db/postgresql/postgresql-9999.ebuild
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,472 @@
 | 
			
		||||
# Copyright 1999-2023 Gentoo Authors
 | 
			
		||||
# Distributed under the terms of the GNU General Public License v2
 | 
			
		||||
 | 
			
		||||
EAPI=8
 | 
			
		||||
 | 
			
		||||
PYTHON_COMPAT=( python3_{9,10,11} )
 | 
			
		||||
 | 
			
		||||
inherit flag-o-matic git-r3 linux-info pam python-single-r1 systemd tmpfiles
 | 
			
		||||
 | 
			
		||||
KEYWORDS=""
 | 
			
		||||
 | 
			
		||||
SLOT="9999"
 | 
			
		||||
 | 
			
		||||
EGIT_REPO_URI="https://git.postgresql.org/git/postgresql.git"
 | 
			
		||||
 | 
			
		||||
LICENSE="POSTGRESQL GPL-2"
 | 
			
		||||
DESCRIPTION="PostgreSQL RDBMS"
 | 
			
		||||
HOMEPAGE="https://www.postgresql.org/"
 | 
			
		||||
 | 
			
		||||
IUSE="debug icu kerberos ldap llvm +lz4
 | 
			
		||||
	nls pam perl python +readline selinux server systemd
 | 
			
		||||
	ssl static-libs tcl threads uuid xml zlib zstd"
 | 
			
		||||
 | 
			
		||||
REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )"
 | 
			
		||||
 | 
			
		||||
CDEPEND="
 | 
			
		||||
>=app-eselect/eselect-postgresql-2.0
 | 
			
		||||
acct-group/postgres
 | 
			
		||||
acct-user/postgres
 | 
			
		||||
sys-apps/less
 | 
			
		||||
virtual/libintl
 | 
			
		||||
icu? ( dev-libs/icu:= )
 | 
			
		||||
kerberos? ( virtual/krb5 )
 | 
			
		||||
ldap? ( net-nds/openldap:= )
 | 
			
		||||
llvm? (
 | 
			
		||||
	sys-devel/llvm:=
 | 
			
		||||
	sys-devel/clang:=
 | 
			
		||||
)
 | 
			
		||||
lz4? ( app-arch/lz4 )
 | 
			
		||||
pam? ( sys-libs/pam )
 | 
			
		||||
perl? ( >=dev-lang/perl-5.8:= )
 | 
			
		||||
python? ( ${PYTHON_DEPS} )
 | 
			
		||||
readline? ( sys-libs/readline:0= )
 | 
			
		||||
ssl? ( >=dev-libs/openssl-0.9.6-r1:0= )
 | 
			
		||||
systemd? ( sys-apps/systemd )
 | 
			
		||||
tcl? ( >=dev-lang/tcl-8:0= )
 | 
			
		||||
uuid? ( dev-libs/ossp-uuid )
 | 
			
		||||
xml? ( dev-libs/libxml2 dev-libs/libxslt )
 | 
			
		||||
zlib? ( sys-libs/zlib )
 | 
			
		||||
zstd? ( app-arch/zstd )
 | 
			
		||||
"
 | 
			
		||||
 | 
			
		||||
# uuid flags -- depend on sys-apps/util-linux for Linux libcs, or if no
 | 
			
		||||
# supported libc in use depend on dev-libs/ossp-uuid. For BSD systems,
 | 
			
		||||
# the libc includes UUID functions.
 | 
			
		||||
UTIL_LINUX_LIBC=( elibc_{glibc,musl} )
 | 
			
		||||
 | 
			
		||||
nest_usedep() {
 | 
			
		||||
	local front back
 | 
			
		||||
	while [[ ${#} -gt 1 ]]; do
 | 
			
		||||
		front+="${1}? ( "
 | 
			
		||||
		back+=" )"
 | 
			
		||||
		shift
 | 
			
		||||
	done
 | 
			
		||||
	echo "${front}${1}${back}"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
CDEPEND+="
 | 
			
		||||
uuid? (
 | 
			
		||||
	${UTIL_LINUX_LIBC[@]/%/? ( sys-apps/util-linux )}
 | 
			
		||||
	$(nest_usedep ${UTIL_LINUX_LIBC[@]/#/!} dev-libs/ossp-uuid)
 | 
			
		||||
)"
 | 
			
		||||
 | 
			
		||||
DEPEND="${CDEPEND}
 | 
			
		||||
>=dev-lang/perl-5.8
 | 
			
		||||
app-text/docbook-dsssl-stylesheets
 | 
			
		||||
app-text/docbook-sgml-dtd:4.5
 | 
			
		||||
app-text/docbook-xml-dtd:4.5
 | 
			
		||||
app-text/docbook-xsl-stylesheets
 | 
			
		||||
app-text/openjade
 | 
			
		||||
dev-libs/libxml2
 | 
			
		||||
dev-libs/libxslt
 | 
			
		||||
sys-devel/bison
 | 
			
		||||
sys-devel/flex
 | 
			
		||||
nls? ( sys-devel/gettext )
 | 
			
		||||
xml? ( virtual/pkgconfig )
 | 
			
		||||
"
 | 
			
		||||
RDEPEND="${CDEPEND}
 | 
			
		||||
selinux? ( sec-policy/selinux-postgresql )
 | 
			
		||||
"
 | 
			
		||||
 | 
			
		||||
pkg_pretend() {
 | 
			
		||||
	if ! use server; then
 | 
			
		||||
		elog "You are using a live ebuild that uses the current source code as it is"
 | 
			
		||||
		elog "available from PostgreSQL's Git repository at emerge time. Given such,"
 | 
			
		||||
		elog "the GNU Makefiles may be altered by upstream without notice and the"
 | 
			
		||||
		elog "documentation for this live version is not readily available"
 | 
			
		||||
		elog "online. Ergo, the ebuild maintainers will not support building a"
 | 
			
		||||
		elog "client-only and/or document-free version."
 | 
			
		||||
		ewarn "Building server anyway."
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_setup() {
 | 
			
		||||
	CONFIG_CHECK="~SYSVIPC" linux-info_pkg_setup
 | 
			
		||||
 | 
			
		||||
	use python && python-single-r1_pkg_setup
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_prepare() {
 | 
			
		||||
	# Set proper run directory
 | 
			
		||||
	sed "s|\(PGSOCKET_DIR\s\+\)\"/tmp\"|\1\"${EPREFIX}/run/postgresql\"|" \
 | 
			
		||||
		-i src/include/pg_config_manual.h || die
 | 
			
		||||
 | 
			
		||||
	# Rely on $PATH being in the proper order so that the correct
 | 
			
		||||
	# install program is used for modules utilizing PGXS in both
 | 
			
		||||
	# hardened and non-hardened environments. (Bug #528786)
 | 
			
		||||
	sed 's/@install_bin@/install -c/' -i src/Makefile.global.in || die
 | 
			
		||||
 | 
			
		||||
	if use pam ; then
 | 
			
		||||
		sed -e "s/\(#define PGSQL_PAM_SERVICE \"postgresql\)/\1-${SLOT}/" \
 | 
			
		||||
			-i src/backend/libpq/auth.c || \
 | 
			
		||||
			die 'PGSQL_PAM_SERVICE rename failed.'
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	eapply_user
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_configure() {
 | 
			
		||||
	case ${CHOST} in
 | 
			
		||||
		*-darwin*|*-solaris*)
 | 
			
		||||
			use nls && append-libs intl
 | 
			
		||||
			;;
 | 
			
		||||
	esac
 | 
			
		||||
 | 
			
		||||
	export LDFLAGS_SL="${LDFLAGS}"
 | 
			
		||||
	export LDFLAGS_EX="${LDFLAGS}"
 | 
			
		||||
 | 
			
		||||
	local PO="${EPREFIX}"
 | 
			
		||||
 | 
			
		||||
	local i uuid_config=""
 | 
			
		||||
	if use uuid; then
 | 
			
		||||
		for i in ${UTIL_LINUX_LIBC[@]}; do
 | 
			
		||||
			use ${i} && uuid_config="--with-uuid=e2fs"
 | 
			
		||||
		done
 | 
			
		||||
		[[ -z $uuid_config ]] && uuid_config="--with-uuid=ossp"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	local myconf="\
 | 
			
		||||
		--prefix="${PO}/usr/$(get_libdir)/postgresql-${SLOT}" \
 | 
			
		||||
		--datadir="${PO}/usr/share/postgresql-${SLOT}" \
 | 
			
		||||
		--includedir="${PO}/usr/include/postgresql-${SLOT}" \
 | 
			
		||||
		--mandir="${PO}/usr/share/postgresql-${SLOT}/man" \
 | 
			
		||||
		--sysconfdir="${PO}/etc/postgresql-${SLOT}" \
 | 
			
		||||
		--with-system-tzdata="${PO}/usr/share/zoneinfo" \
 | 
			
		||||
		$(use_enable debug) \
 | 
			
		||||
		$(use_enable nls) \
 | 
			
		||||
		$(use_enable threads thread-safety) \
 | 
			
		||||
		$(use_with icu) \
 | 
			
		||||
		$(use_with kerberos gssapi) \
 | 
			
		||||
		$(use_with ldap) \
 | 
			
		||||
		$(use_with llvm) \
 | 
			
		||||
		$(use_with lz4) \
 | 
			
		||||
		$(use_with pam) \
 | 
			
		||||
		$(use_with perl) \
 | 
			
		||||
		$(use_with python) \
 | 
			
		||||
		$(use_with readline) \
 | 
			
		||||
		$(use_with ssl openssl) \
 | 
			
		||||
		$(use_with tcl) \
 | 
			
		||||
		$(use_with xml libxml) \
 | 
			
		||||
		$(use_with xml libxslt) \
 | 
			
		||||
		$(use_with zlib) \
 | 
			
		||||
		$(use_with zstd ) \
 | 
			
		||||
		$(use_with systemd) \
 | 
			
		||||
		${uuid_config}"
 | 
			
		||||
	if use alpha; then
 | 
			
		||||
		myconf+=" --disable-spinlocks"
 | 
			
		||||
	else
 | 
			
		||||
		# Should be the default but just in case
 | 
			
		||||
		myconf+=" --enable-spinlocks"
 | 
			
		||||
	fi
 | 
			
		||||
	econf ${myconf}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_compile() {
 | 
			
		||||
	emake world
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_install() {
 | 
			
		||||
	emake DESTDIR="${D}" install-world
 | 
			
		||||
 | 
			
		||||
	dodoc README HISTORY doc/TODO
 | 
			
		||||
 | 
			
		||||
	insinto /etc/postgresql-${SLOT}
 | 
			
		||||
	newins src/bin/psql/psqlrc.sample psqlrc
 | 
			
		||||
 | 
			
		||||
	# Don't delete libpg{port,common}.a (Bug #571046). They're always
 | 
			
		||||
	# needed by extensions utilizing PGXS.
 | 
			
		||||
	use static-libs || \
 | 
			
		||||
		find "${ED}" -name '*.a' ! -name libpgport.a ! -name libpgcommon.a \
 | 
			
		||||
			 -delete
 | 
			
		||||
 | 
			
		||||
	sed -e "s|@SLOT@|${SLOT}|g" -e "s|@LIBDIR@|$(get_libdir)|g" \
 | 
			
		||||
		"${FILESDIR}/${PN}.confd-9.3" | newconfd - ${PN}-${SLOT}
 | 
			
		||||
 | 
			
		||||
	sed -e "s|@SLOT@|${SLOT}|g" -e "s|@LIBDIR@|$(get_libdir)|g" \
 | 
			
		||||
		"${FILESDIR}/${PN}.init-9.3-r1" | newinitd - ${PN}-${SLOT}
 | 
			
		||||
 | 
			
		||||
	if use systemd; then
 | 
			
		||||
		sed -e "s|@SLOT@|${SLOT}|g" -e "s|@LIBDIR@|$(get_libdir)|g" \
 | 
			
		||||
			"${FILESDIR}/${PN}.service-9.6-r1" | \
 | 
			
		||||
			systemd_newunit - ${PN}-${SLOT}.service
 | 
			
		||||
		newtmpfiles "${FILESDIR}"/${PN}.tmpfiles ${PN}-${SLOT}.conf
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	newbin "${FILESDIR}"/${PN}-check-db-dir ${PN}-${SLOT}-check-db-dir
 | 
			
		||||
 | 
			
		||||
	use pam && pamd_mimic system-auth ${PN}-${SLOT} auth account session
 | 
			
		||||
 | 
			
		||||
	local f bn
 | 
			
		||||
	for f in $(find "${ED}/usr/$(get_libdir)/postgresql-${SLOT}/bin" \
 | 
			
		||||
					-mindepth 1 -maxdepth 1)
 | 
			
		||||
	do
 | 
			
		||||
		bn=$(basename "${f}")
 | 
			
		||||
		# Temporarily tack on tmp to workaround a file collision
 | 
			
		||||
		# issue. This is only necessary for 9.7 and earlier. 10 never
 | 
			
		||||
		# had this issue.
 | 
			
		||||
		dosym "../$(get_libdir)/postgresql-${SLOT}/bin/${bn}" \
 | 
			
		||||
			  "/usr/bin/${bn}${SLOT/.}tmp"
 | 
			
		||||
	done
 | 
			
		||||
 | 
			
		||||
	# Create slot specific man pages
 | 
			
		||||
	local bn f mansec slotted_name
 | 
			
		||||
	for mansec in 1 3 7 ; do
 | 
			
		||||
		local rel_manpath="../../postgresql-${SLOT}/man/man${mansec}"
 | 
			
		||||
 | 
			
		||||
		mkdir -p "${ED}"/usr/share/man/man${mansec} || die "making man dir"
 | 
			
		||||
		pushd "${ED}"/usr/share/man/man${mansec} > /dev/null || die "pushd failed"
 | 
			
		||||
 | 
			
		||||
		for f in "${ED}/usr/share/postgresql-${SLOT}/man/man${mansec}"/* ; do
 | 
			
		||||
			bn=$(basename "${f}")
 | 
			
		||||
			slotted_name=${bn%.${mansec}}${SLOT}.${mansec}
 | 
			
		||||
			case ${bn} in
 | 
			
		||||
				TABLE.7|WITH.7)
 | 
			
		||||
					echo ".so ${rel_manpath}/SELECT.7" > ${slotted_name}
 | 
			
		||||
					;;
 | 
			
		||||
				*)
 | 
			
		||||
					echo ".so ${rel_manpath}/${bn}" > ${slotted_name}
 | 
			
		||||
					;;
 | 
			
		||||
			esac
 | 
			
		||||
		done
 | 
			
		||||
 | 
			
		||||
		popd > /dev/null
 | 
			
		||||
	done
 | 
			
		||||
 | 
			
		||||
	if use prefix ; then
 | 
			
		||||
		keepdir /run/postgresql
 | 
			
		||||
		fperms 1775 /run/postgresql
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_preinst() {
 | 
			
		||||
	# Find all of the slot-specific symlinks, if any, in /usr/bin (e.g.,
 | 
			
		||||
	# /usr/bin/psql97). They may have been created by the
 | 
			
		||||
	# postgresql.eselect module, but they're handled within this ebuild
 | 
			
		||||
	# now. It's alright if we momentarily delete /usr/bin/psql as it
 | 
			
		||||
	# will be recreated by the eselect module in pkg_ppostinst().  We
 | 
			
		||||
	# only worry about the 9.7 slot as that's the last slot that had its
 | 
			
		||||
	# slot-specific links generated by eselect.
 | 
			
		||||
	#
 | 
			
		||||
	# This can be removed when 10 is the lowest slot in the tree.
 | 
			
		||||
	local canonicalise
 | 
			
		||||
	if type -p realpath > /dev/null; then
 | 
			
		||||
		canonicalise=realpath
 | 
			
		||||
	elif type -p readlink > /dev/null; then
 | 
			
		||||
		canonicalise='readlink -f'
 | 
			
		||||
	else
 | 
			
		||||
		# can't die, subshell
 | 
			
		||||
		die "No readlink nor realpath found, cannot canonicalise"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	local l
 | 
			
		||||
	# First remove any symlinks in /usr/bin that may have been created
 | 
			
		||||
	# by the old eselect
 | 
			
		||||
	for l in $(find "${ROOT}/usr/bin" -mindepth 1 -maxdepth 1 -type l) ; do
 | 
			
		||||
		[[ $(${canonicalise} "${l}") == *postgresql-9.7* ]] && rm "${l}"
 | 
			
		||||
	done
 | 
			
		||||
 | 
			
		||||
	# Then move the symlinks created by the ebuild to their proper place.
 | 
			
		||||
	for l in "${ED}"/usr/bin/*tmp ; do
 | 
			
		||||
		mv "${l}" "${l%tmp}" \
 | 
			
		||||
			|| ewarn "Couldn't rename $(basename ${l}) to $(basename ${l%tmp})"
 | 
			
		||||
	done
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_postinst() {
 | 
			
		||||
	use systemd && tmpfiles_process ${PN}-${SLOT}.conf
 | 
			
		||||
	postgresql-config update
 | 
			
		||||
 | 
			
		||||
	elog "If you need a global psqlrc-file, you can place it in:"
 | 
			
		||||
	elog "    ${EROOT}/etc/postgresql-${SLOT}/"
 | 
			
		||||
 | 
			
		||||
	elog
 | 
			
		||||
	elog "Gentoo specific documentation:"
 | 
			
		||||
	elog "https://wiki.gentoo.org/wiki/PostgreSQL"
 | 
			
		||||
	elog
 | 
			
		||||
	elog "Official documentation:"
 | 
			
		||||
	elog "${EROOT}/usr/share/doc/${PF}/html"
 | 
			
		||||
	elog
 | 
			
		||||
	elog "The default location of the Unix-domain socket is:"
 | 
			
		||||
	elog "    ${EROOT}/run/postgresql/"
 | 
			
		||||
	elog
 | 
			
		||||
	elog "Before initializing the database, you may want to edit PG_INITDB_OPTS"
 | 
			
		||||
	elog "so that it contains your preferred locale, and other options, in:"
 | 
			
		||||
	elog "    ${EROOT}/etc/conf.d/postgresql-${SLOT}"
 | 
			
		||||
	elog
 | 
			
		||||
	elog "Then, execute the following command to setup the initial database"
 | 
			
		||||
	elog "environment:"
 | 
			
		||||
	elog "    emerge --config =${CATEGORY}/${PF}"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_prerm() {
 | 
			
		||||
	if [[ -z ${REPLACED_BY_VERSION} ]] ; then
 | 
			
		||||
		ewarn "Have you dumped and/or migrated the ${SLOT} database cluster?"
 | 
			
		||||
		ewarn "\thttps://wiki.gentoo.org/wiki/PostgreSQL/QuickStart#Migrating_PostgreSQL"
 | 
			
		||||
 | 
			
		||||
		ebegin "Resuming removal in 10 seconds (Control-C to cancel)"
 | 
			
		||||
		sleep 10
 | 
			
		||||
		eend 0
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_postrm() {
 | 
			
		||||
	postgresql-config update
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_config() {
 | 
			
		||||
	[[ -f "${EROOT}/etc/conf.d/postgresql-${SLOT}" ]] \
 | 
			
		||||
		&& source "${EROOT}/etc/conf.d/postgresql-${SLOT}"
 | 
			
		||||
	[[ -z "${PGDATA}" ]] && PGDATA="${EROOT}/etc/postgresql-${SLOT}/"
 | 
			
		||||
	[[ -z "${DATA_DIR}" ]] \
 | 
			
		||||
		&& DATA_DIR="${EROOT}/var/lib/postgresql/${SLOT}/data"
 | 
			
		||||
 | 
			
		||||
	# environment.bz2 may not contain the same locale as the current system
 | 
			
		||||
	# locale. Unset and source from the current system locale.
 | 
			
		||||
	if [ -f "${EROOT}/etc/env.d/02locale" ]; then
 | 
			
		||||
		unset LANG
 | 
			
		||||
		unset LC_CTYPE
 | 
			
		||||
		unset LC_NUMERIC
 | 
			
		||||
		unset LC_TIME
 | 
			
		||||
		unset LC_COLLATE
 | 
			
		||||
		unset LC_MONETARY
 | 
			
		||||
		unset LC_MESSAGES
 | 
			
		||||
		unset LC_ALL
 | 
			
		||||
		source "${EROOT}/etc/env.d/02locale"
 | 
			
		||||
		[ -n "${LANG}" ] && export LANG
 | 
			
		||||
		[ -n "${LC_CTYPE}" ] && export LC_CTYPE
 | 
			
		||||
		[ -n "${LC_NUMERIC}" ] && export LC_NUMERIC
 | 
			
		||||
		[ -n "${LC_TIME}" ] && export LC_TIME
 | 
			
		||||
		[ -n "${LC_COLLATE}" ] && export LC_COLLATE
 | 
			
		||||
		[ -n "${LC_MONETARY}" ] && export LC_MONETARY
 | 
			
		||||
		[ -n "${LC_MESSAGES}" ] && export LC_MESSAGES
 | 
			
		||||
		[ -n "${LC_ALL}" ] && export LC_ALL
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	einfo "You can modify the paths and options passed to initdb by editing:"
 | 
			
		||||
	einfo "    ${EROOT}/etc/conf.d/postgresql-${SLOT}"
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "Information on options that can be passed to initdb are found at:"
 | 
			
		||||
	einfo "    https://www.postgresql.org/docs/${SLOT}/static/creating-cluster.html"
 | 
			
		||||
	einfo "    https://www.postgresql.org/docs/${SLOT}/static/app-initdb.html"
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "PG_INITDB_OPTS is currently set to:"
 | 
			
		||||
	if [[ -z "${PG_INITDB_OPTS}" ]] ; then
 | 
			
		||||
		einfo "    (none)"
 | 
			
		||||
	else
 | 
			
		||||
		einfo "    ${PG_INITDB_OPTS}"
 | 
			
		||||
	fi
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "Configuration files will be installed to:"
 | 
			
		||||
	einfo "    ${PGDATA}"
 | 
			
		||||
	einfo
 | 
			
		||||
	einfo "The database cluster will be created in:"
 | 
			
		||||
	einfo "    ${DATA_DIR}"
 | 
			
		||||
	einfo
 | 
			
		||||
 | 
			
		||||
	ebegin "Continuing initialization in 5 seconds (Control-C to cancel)"
 | 
			
		||||
	sleep 5
 | 
			
		||||
	eend 0
 | 
			
		||||
 | 
			
		||||
	if [ -n "$(ls -A ${DATA_DIR} 2> /dev/null)" ] ; then
 | 
			
		||||
		eerror "The given directory, '${DATA_DIR}', is not empty."
 | 
			
		||||
		eerror "Modify DATA_DIR to point to an empty directory."
 | 
			
		||||
		die "${DATA_DIR} is not empty."
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	einfo "Creating the data directory ..."
 | 
			
		||||
	if [[ ${EUID} == 0 ]] ; then
 | 
			
		||||
		mkdir -p "${DATA_DIR}"
 | 
			
		||||
		chown -Rf postgres:postgres "${DATA_DIR}"
 | 
			
		||||
		chmod 0700 "${DATA_DIR}"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	einfo "Initializing the database ..."
 | 
			
		||||
 | 
			
		||||
	if [[ ${EUID} == 0 ]] ; then
 | 
			
		||||
		su - postgres -c "${EROOT}/usr/$(get_libdir)/postgresql-${SLOT}/bin/initdb -D \"${DATA_DIR}\" ${PG_INITDB_OPTS}"
 | 
			
		||||
	else
 | 
			
		||||
		"${EROOT}"/usr/$(get_libdir)/postgresql-${SLOT}/bin/initdb -U postgres -D "${DATA_DIR}" ${PG_INITDB_OPTS}
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	if [[ "${DATA_DIR%/}" != "${PGDATA%/}" ]] ; then
 | 
			
		||||
		mv "${DATA_DIR%/}"/{pg_{hba,ident},postgresql}.conf "${PGDATA}"
 | 
			
		||||
		ln -s "${PGDATA%/}"/{pg_{hba,ident},postgresql}.conf "${DATA_DIR%/}"
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	# unix_socket_directory has no effect in postgresql.conf as it's
 | 
			
		||||
	# overridden in the initscript
 | 
			
		||||
	sed '/^#unix_socket_directories/,+1d' -i "${PGDATA%/}"/postgresql.conf
 | 
			
		||||
 | 
			
		||||
	cat <<- EOF >> "${PGDATA%/}"/postgresql.conf
 | 
			
		||||
		# This is here because of https://bugs.gentoo.org/show_bug.cgi?id=518522
 | 
			
		||||
		# On the off-chance that you might need to work with UTF-8 encoded
 | 
			
		||||
		# characters in PL/Perl
 | 
			
		||||
		plperl.on_init = 'use utf8; use re; package utf8; require "utf8_heavy.pl";'
 | 
			
		||||
	EOF
 | 
			
		||||
 | 
			
		||||
	einfo "The autovacuum function, which was in contrib, has been moved to the main"
 | 
			
		||||
	einfo "PostgreSQL functions starting with 8.1, and starting with 8.4 is now enabled"
 | 
			
		||||
	einfo "by default. You can disable it in the cluster's:"
 | 
			
		||||
	einfo "    ${PGDATA%/}/postgresql.conf"
 | 
			
		||||
	einfo
 | 
			
		||||
	if ! use systemd; then
 | 
			
		||||
		einfo "The PostgreSQL server, by default, will log events to:"
 | 
			
		||||
		einfo "    ${DATA_DIR%/}/postmaster.log"
 | 
			
		||||
		einfo
 | 
			
		||||
	fi
 | 
			
		||||
	if use prefix ; then
 | 
			
		||||
		einfo "The location of the configuration files have moved to:"
 | 
			
		||||
		einfo "    ${PGDATA}"
 | 
			
		||||
		einfo "To start the server:"
 | 
			
		||||
		einfo "    pg_ctl start -D ${DATA_DIR} -o '-D ${PGDATA} --data-directory=${DATA_DIR}'"
 | 
			
		||||
		einfo "To stop:"
 | 
			
		||||
		einfo "    pg_ctl stop -D ${DATA_DIR}"
 | 
			
		||||
		einfo
 | 
			
		||||
		einfo "Or move the configuration files back:"
 | 
			
		||||
		einfo "mv ${PGDATA}*.conf ${DATA_DIR}"
 | 
			
		||||
	elif use systemd; then
 | 
			
		||||
		einfo "You should use the 'postgresql-${SLOT}.service' unit to run PostgreSQL"
 | 
			
		||||
		einfo "instead of 'pg_ctl'."
 | 
			
		||||
	else
 | 
			
		||||
		einfo "You should use the '${EROOT}/etc/init.d/postgresql-${SLOT}' script to run PostgreSQL"
 | 
			
		||||
		einfo "instead of 'pg_ctl'."
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
src_test() {
 | 
			
		||||
	if [[ ${UID} -ne 0 ]] ; then
 | 
			
		||||
		# Some ICU tests fail if LC_CTYPE and LC_COLLATE aren't the same. We set
 | 
			
		||||
		# LC_CTYPE to be equal to LC_COLLATE since LC_COLLATE is set by Portage.
 | 
			
		||||
		local old_ctype=${LC_CTYPE}
 | 
			
		||||
		export LC_CTYPE=${LC_COLLATE}
 | 
			
		||||
		emake check
 | 
			
		||||
		export LC_CTYPE=${old_ctype}
 | 
			
		||||
 | 
			
		||||
		einfo "If you think other tests besides the regression tests are necessary, please"
 | 
			
		||||
		einfo "submit a bug including a patch for this ebuild to enable them."
 | 
			
		||||
	else
 | 
			
		||||
		ewarn 'Tests cannot be run as root. Enable "userpriv" in FEATURES.'
 | 
			
		||||
		ewarn 'Skipping.'
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user