Feedback: feedback, bugfixes, and brain-dead shell workarounds
for the install scripts by Victor Duchovny and Simon Mudd.
+20020113
+
+ Rewrote postfix-install. The postfix-files file now controls
+ what is installed. Refined the semantics of many post-install
+ operations. post-install now auto-saves settings that override
+ main.cf.
+
Open problems:
Low: don't do user@domain and @domain lookups in
tidy: clean
rm -f Makefile */Makefile src/*/Makefile
cp Makefile.init Makefile
- rm -f bin/* lib/* include/* libexec/* \
+ rm -f bin/[!CRS]* lib/[!CRS]* include/[!CRS]* libexec/[!CRS]* \
junk */junk */*/junk \
*core */*core */*/*core \
.nfs* */.nfs* */*/.nfs* \
+Incompatible changes with snapshot-20020113
+===========================================
+
+Another revision of installation procedures. The command interface
+of the postfix-install and $config_directory/post-install scripts
+has changed; see embedded documentation. postfix-install no longer has
+hard-coded commands to install files: $config_directory/postfix-files
+now controls what files are installed. The post-install script now
+automatically saves installation parameters to the main.cf file.
+
Incompatible changes with snapshot-20020111
===========================================
Postfix, and apply the correct file/directory ownerships and
permissions by executing the post-install script as:
- post-install set-permissions config_directory=/etc/postfix
+ post-install set-permissions setgid_group=groupname
Incompatible changes with snapshot-20020110
===========================================
#!/bin/sh
-# To view the formatted manual page of this file, type:
+# To view the formatted manual page of this file, type:
# POSTFIXSOURCE/mantools/srctoman - post-install | nroff -man
#++
# installation, after the executable programs and configuration
# files are installed. Usage is one of the following:
# .IP o
-# While installing Postfix from source code on the local machine, the
+# While installing Postfix from source code on the local machine, the
# script is run by the postfix-install script to update selected file
-# or directory permissions and to update selected configuration files.
+# or directory permissions and to update Postfix configuration files.
# .IP o
-# While installing Postfix from a pre-built package, the script is run
-# by the package management procedure to set all file or directory
-# permissions and to update existing Postfix configuration files.
+# While installing Postfix from a pre-built package, the script is run
+# by the package management procedure to set all file or directory
+# permissions and to update Postfix configuration files.
# .IP o
-# At Postfix start-up time, the script is run from "postfix check" to
+# The script can be used to change installation parameter settings such
+# as mail_owner or setgid_group after Postfix is already installed.
+# .IP o
+# The script can be used to upgrade configuration files and to upgrade
+# file/directory permissions of a secondary Postfix instance.
+# .IP o
+# At Postfix start-up time, the script is run from "postfix check" to
# create missing queue directories.
# .PP
+# The post-install script is controlled by installation parameters.
+# Specific parameters are described at the end of this document.
+# All installation parameters must be specified ahead of time via
+# one of the methods described below.
+#
# Arguments
# .IP create-missing
# Create missing queue directories with ownerships and permissions
-# according to the contents of $config_directory/postfix-files.
+# according to the contents of $config_directory/postfix-files, using
+# the mail_owner and setgid_group parameter settings from the command
+# line, process environment or from the installed main.cf file.
#
# This is required at Postfix start-up time.
# .IP set-permissions
-# Set all file/directory ownerships and permissions according to the
-# contents of $config_directory/postfix-files. Implies create-missing.
+# Set all file/directory ownerships and permissions according to the
+# contents of $config_directory/postfix-files, using the mail_owner
+# and setgid_group parameter settings from the command line, process
+# environment or from the installed main.cf file. Implies create-missing.
#
-# This is required when installing Postfix from a pre-built package.
+# This is required when installing Postfix from a pre-built package,
+# or when changing the mail_owner or setgid_group installation parameter
+# settings after Postfix is already installed.
# .IP upgrade-permissions
-# Update ownership and permission of selected files/directories as
-# specified in $config_directory/postfix-files. Implies create-missing.
+# Update ownership and permission of existing files/directories as
+# specified in $config_directory/postfix-files, using the mail_owner
+# and setgid_group parameter settings from the command line, process
+# environment or from the installed main.cf file. Implies create-missing.
#
-# This is required when installing Postfix from source code, while
-# Postfix was already installed on the machine.
+# This is required when upgrading an existing Postfix instance.
# .IP upgrade-configuration
-# Edit the installed main.cf and master.cf files, in order to account
-# for missing services and to fix deprecated parameter settings.
+# Edit the installed main.cf and master.cf files, in order to account
+# for missing services and to fix deprecated parameter settings.
#
-# This is required when Postfix was already installed on the machine.
+# This is required when upgrading an existing Postfix instance.
# .IP upgrade-source
-# Short-hand for upgrade-permissions upgrade-configuration.
+# Short-hand for: upgrade-permissions upgrade-configuration.
#
# This is recommended when upgrading Postfix from source code.
# .IP upgrade-package
-# Short-hand for set-permissions upgrade-configuration.
+# Short-hand for: set-permissions upgrade-configuration.
#
# This is recommended when upgrading Postfix from a pre-built package.
# .IP first-install-reminder
# Remind the user that they still need to configure main.cf and the
-# aliases file, and that newaliases needs to be run.
+# aliases file, and that newaliases still needs to be run.
#
# This is recommended when Postfix is installed for the first time.
-# .IP config_directory=pathname
-# Absolute pathname of the directory with Postfix configuration files.
-# This information must be specified if it is not given via the
-# process environment.
-# .IP command_directory=pathname
-# Absolute pathname of the directory with the postconf command.
-# This information must be specified if it is not given via the
-# process environment, and if the directory is not a standard
-# system directory.
+# MULTIPLE POSTFIX INSTANCES
+# .ad
+# .fi
+# Multiple Postfix instances on the same machine can share command and
+# daemon program files but must have separate configuration and queue
+# directories.
+#
+# To create a secondary Postfix installation on the same machine,
+# copy the configuration files from the primary Postfix instance to
+# a secondary configuration directory and execute:
+#
+# post-install config_directory=secondary-config-directory \e
+# .in +4
+# queue_directory=secondary-queue-directory \e
+# .br
+# create-missing
+# .PP
+# This creates secondary Postfix queue directories, sets their access
+# permissions, and saves the specified installation parameters to the
+# secondary main.cf file.
+#
+# Be sure to list the secondary configuration directory in the
+# alternate_config_directories parameter in the primary main.cf file.
+#
+# To upgrade a secondary Postfix installation on the same machine,
+# execute:
+#
+# post-install config_directory=secondary-config-directory \e
+# .in +4
+# upgrade-permissions upgrade-configuration
+# INSTALLATION PARAMETER INPUT METHODS
+# .ad
+# .fi
+# Parameter settings can be specified through a variety of
+# mechanisms. In order of decreasing precedence these are:
+# .IP "command line"
+# Parameter settings can be given as name=value arguments on
+# the post-install command line. These have the highest precedence.
+# Settings that override the installed main.cf file are saved.
+# .IP "process environment"
+# Parameter settings can be given as name=value environment
+# variables.
+# Settings that override the installed main.cf file are saved.
+# .IP "installed configuration files"
+# If a parameter is not specified via the command line or via the
+# process environment, post-install will attempt to extract its
+# value from the already installed Postfix main.cf configuration file.
+# These settings have the lowest precedence.
+# INSTALLATION PARAMETER DESCRIPTION
+# .ad
+# .fi
+# The description of installation parameters is as follows:
+# .IP config_directory
+# The directory for Postfix configuration files.
+# .IP daemon_directory
+# The directory for Postfix daemon programs. This directory
+# should not be in the command search path of any users.
+# .IP command_directory
+# The directory for Postfix administrative commands. This
+# directory should be in the command search path of adminstrative users.
+# .IP queue_directory
+# The directory for Postfix queues.
+# .IP sendmail_path
+# The full pathname for the Postfix sendmail command.
+# This is the Sendmail-compatible mail posting interface.
+# .IP newaliases_path
+# The full pathname for the Postfix newaliases command.
+# This is the Sendmail-compatible command to build alias databases
+# for the Postfix local delivery agent.
+# .IP mailq_path
+# The full pathname for the Postfix mailq command.
+# This is the Sendmail-compatible command to list the mail queue.
+# .IP mail_owner
+# The owner of the Postfix queue. Its numerical user ID and group ID
+# must not be used by any other accounts on the system.
+# .IP setgid_group
+# The group for mail submission and for queue management commands.
+# Its numerical group ID must not be used by any other accounts on the
+# system, not even by the mail_owner account.
+# .IP manpage_path
+# The directory for the Postfix on-line manual pages.
# SEE ALSO
# postfix-install(1) Postfix primary installation script.
# FILES
-# $config_directory/main.cf, Postfix installation configuration.
-# $config_directory/postfix-files, permissions and ownerships.
-# This file is created by postfix-install.
+# $config_directory/main.cf, Postfix installation parameters.
+# $config_directory/postfix-files, installation control file.
+# $config_directory/install.cf, obsolete configuration file.
# LICENSE
# .ad
# .fi
SHELL=/bin/sh
IFS="
"
+BACKUP_IFS="$IFS"
USAGE="Usage: $0 [name=value] command
create-missing Create missing queue directories.
- upgrade-source Use when upgrading from source.
- upgrade-package Use when upgrading from pre-built package.
- first-install-reminder Remind of mandatory configuration steps.
- config_directory=path Specify an absolute path name.
- command_directory=path Specify an absolute path name."
+ upgrade-source When installing or upgrading from source code.
+ upgrade-package When installing or upgrading from pre-built package.
+ first-install-reminder Remind of mandatory first-time configuration steps.
+ name=value Specify an installation parameter".
# Process command-line options and parameter settings. Work around
-# brain damaged shells. "name=value command" should not make the
-# name=value setting permanent.
+# brain damaged shells. "IFS=value command" should not make the
+# IFS=value setting permanent. But some broken standard allows it.
create=; set_perms=; upgrade_perms=; upgrade_conf=; first_install_reminder=
for arg
do
case $arg in
- *=*) SAVED_IFS="$IFS"; IFS= eval $arg; IFS="$SAVED_IFS";;
+ *=*) IFS= eval $arg; IFS="$BACKUP_IFS";;
create-missing) create=1;;
set-perm*) create=1; set_perms=1;;
upgrade-perm*) create=1; upgrade_perms=1;;
upgrade-source) create=1; upgrade_conf=1; upgrade_perms=1;;
upgrade-package) create=1; upgrade_conf=1; set_perms=1;;
first-install*) first_install_reminder=1;;
- "") break;;
- *) echo "Error: $USAGE" 1>&2; exit 1;;
+ *) echo "$0: Error: $USAGE" 1>&2; exit 1;;
esac
shift
done
# Sanity checks.
test -n "$create$upgrade_conf$first_install_reminder" || {
- echo "Error: $USAGE" 1>&2
+ echo "$0: Error: $USAGE" 1>&2
exit 1
}
-test -n "$config_directory" || {
- echo "Error: no config_directory parameter setting." 1>&2
- echo "$USAGE" 1>&2
- exit 1
-}
+# Bootstrapping problem.
+
+if [ -n "$command_directory" ]
+then
+ POSTCONF="$command_directory/postconf"
+else
+ POSTCONF="postconf"
+fi
+
+test -n "$config_directory" ||
+ config_directory=`$POSTCONF -d -h config_directory` || exit 1
test -d "$config_directory" || {
- echo Error: $config_directory is not a directory. 1>&2
+ echo $0: Error: $config_directory is not a directory. 1>&2
exit 1
}
test -f $config_directory/postfix-files || {
- Error: $config_directory/postfix-files is not a file. 1>&2
+ $0: Error: $config_directory/postfix-files is not a file. 1>&2
exit 1
}
-#
+#
# LINUX by default does not synchronously update directories -
# that's dangerous for mail.
#
CHATTR=echo
fi
-# Bootstrapping problem.
+case `uname -s` in
+HP-UX*) FMT=cat;;
+ *) FMT=fmt;;
+esac
+
+# If a parameter is not set via the command line or environment,
+# try to use settings from installed configuration files.
+
+# Extract parameter settings from the obsolete install.cf file, as
+# a transitional aid.
+
+grep setgid_group $config_directory/main.cf >/dev/null 2>&1 || {
+ test -f $config_directory/install.cf && {
+ for name in sendmail_path newaliases_path mailq_path setgid manpages
+ do
+ eval : \${$name="\`. $config_directory/install.cf; echo \$$name\`"} \
+ || exit 1
+ done
+ : ${setgid_group=$setgid}
+ : ${manpage_path=$manpages}
+ }
+}
-if [ -n "$command_directory" ]
-then
- POSTCONF="$command_directory/postconf"
-else
- POSTCONF="postconf"
-fi
+# Extract parameter settings from the installed main.cf file.
-# Settings from main.cf must override command line or environment settings.
+test -f $config_directory/main.cf && {
+ for name in daemon_directory command_directory queue_directory mail_owner \
+ setgid_group sendmail_path newaliases_path mailq_path manpage_path
+ do
+ eval : \${$name=\`$POSTCONF -c $config_directory -h $name\`} || exit 1
+ done
+}
+
+# Sanity checks
+
+case $manpage_path in
+ no) echo $0: Error: manpage_path no longer accepts \"no\" values. 1>&2
+ echo Re-run this script as \"$0 manpage_path=/pathname $*\". 1>&2; exit 1;;
+esac
+
+case $setgid_group in
+ no) echo $0: Error: setgid_group no longer accepts \"no\" values. 1>&2
+ echo Re-run this script as \"$0 setgid_group=groupname $*\" 1>&2; exit 1;;
+esac
+
+for path in $daemon_directory $command_directory \
+ $queue_directory $sendmail_path $newaliases_path $mailq_path $manpage_path
+do
+ case $path in
+ /*) ;;
+ *) echo $0: Error: $path should be an absolute path name. 1>&2; exit 1;;
+ esac
+done
+# Find out what parameters were not specified via command line,
+# via environment, or via installed configuration files.
+
+missing=
for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path
do
- eval $name=\`$POSTCONF -c $config_directory -h $name\` || kill $$
+ eval test -n \"\$$name\" || missing="$missing $name"
done
+# All parameters must be specified at this point.
+
+test -n "$non_interactive" -a -n "$missing" && {
+ cat <<EOF | ${FMT} 1>&2
+$0: Error: some required installation parameters are not defined.
+
+- Either the parameters need to be given in the $config_directory/main.cf
+file from a recent Postfix installation,
+
+- Or the parameters need to be specified as name=value arguments
+on the $0 command line,
+
+- Or the parameters need to be specified through the process
+environment.
+
+The following parameters were missing:
+
+ $missing
+
+EOF
+ exit 1
+}
+
POSTCONF="$command_directory/postconf"
+# Save settings, allowing command line/environment override.
+
+override=
+for name in daemon_directory command_directory queue_directory mail_owner \
+ setgid_group sendmail_path newaliases_path mailq_path manpage_path
+do
+ eval test \"\$$name\" = \"`$POSTCONF -c $config_directory -h $name`\" || {
+ override=1
+ break
+ }
+done
+
+test -n "$override" && {
+ $POSTCONF -c $config_directory -e \
+ "daemon_directory = $daemon_directory" \
+ "command_directory = $command_directory" \
+ "queue_directory = $queue_directory" \
+ "mail_owner = $mail_owner" \
+ "setgid_group = $setgid_group" \
+ "sendmail_path = $sendmail_path" \
+ "mailq_path = $mailq_path" \
+ "newaliases_path = $newaliases_path" \
+ "manpage_path = $manpage_path" \
+ || exit 1
+}
+
# Use file/directory status information in $config_directory/postfix-files.
test -n "$create" && {
- while IFS=: read path type owner group mode upgrade_flag create_flag junk
+ exec <$config_directory/postfix-files || exit 1
+ while IFS=: read path type owner group mode flags junk
do
+ IFS="$BACKUP_IFS"
set_permission=
+ # Skip comments.
case $path in
- [$]*) eval path=$path;;
- /*) ;;
- *) continue;;
- esac
- case $owner in
- [$]*) eval owner=$owner;;
- esac
- case $group in
- [$]*) eval group=$group;;
+ [/$]*) ;;
+ *) continue;;
esac
+ # Expand $name, and canonicalize null fields.
+ for name in path owner group flags
+ do
+ eval junk=\${$name}
+ case $junk in
+ [$]*) eval $name=$junk;;
+ -) eval $name=;;
+ *) ;;
+ esac
+ done
+ case $flags in *u*) upgrade_flag=1;; *) upgrade_flag=;; esac
+ case $flags in *c*) create_flag=1;; *) create_flag=;; esac
# Create missing directories with proper owner/group/mode settings.
if [ -n "$create" -a "$type" = "d" -a -n "$create_flag" -a ! -d "$path" ]
then
test -z "$group" || chgrp $group $path || exit 1
chmod $mode $path || exit 1
}
- done <$config_directory/postfix-files
+ done
}
# Upgrade existing Postfix configuration files if necessary.
grep 'flush.*flush' $config_directory/master.cf >/dev/null || {
echo Editing $config_directory/master.cf, adding missing entry for flush service
- cat >>$config_directory/master.cf <<EOF
+ cat >>$config_directory/master.cf <<EOF || exit 1
flush unix - - n 1000? 0 flush
EOF
}
grep "^pickup[ ]*fifo[ ]*n[ ]*n" \
$config_directory/master.cf >/dev/null && {
echo Editing $config_directory/master.cf, making the pickup service unprivileged
- ed $config_directory/master.cf <<EOF
+ ed $config_directory/master.cf <<EOF || exit 1
/^pickup[ ]*fifo[ ]*n[ ]*n/
s/\(n[ ]*\)n/\1-/
p
grep "^$name[ ]*unix[ ]*-" \
$config_directory/master.cf >/dev/null && {
echo Editing $config_directory/master.cf, making the $name service public
- ed $config_directory/master.cf <<EOF
+ ed $config_directory/master.cf <<EOF || exit 1
/^$name[ ]*unix[ ]*-/
s/-/n/
p
# be hashed, and so should the other directories, because they
# can contain even more mail.
#
- # Unfortunately, this sucks mailq performance on unloaded systems.
- #
+ # Unfortunately, this sucks mailq performance on unloaded systems.
+ #
# If you don't want slow mailq, be sure to hash defer and deferred,
# because those two directories can contain lots of files.
(echo "$found" | grep deferred>/dev/null)|| missing="$missing deferred"
test -n "$missing" && {
echo fixing main.cf hash_queue_names for missing $missing
- $POSTCONF -c $config_directory -e hash_queue_names="$found$missing"
+ $POSTCONF -c $config_directory -e hash_queue_names="$found$missing" ||
+ exit 1
}
-
}
# A reminder if this is the first time Postfix is being installed.
ALIASES=`$POSTCONF -h alias_database | sed 's/^[^:]*://'`
NEWALIASES_PATH=`$POSTCONF -h newaliases_path`
- cat <<EOF 1>&2
+ cat <<EOF | ${FMT}
Warning: you still need to edit myorigin/mydestination/mynetworks
parameter settings in $config_directory/main.cf.
--- /dev/null
+#
+# Do not edit this file.
+#
+# This file controls the postfix-install script for installation of
+# Postfix programs, configuration files and documentation, as well
+# as the post-install script for setting permissions and for updating
+# Postfix configuration files. See the respective manual pages within
+# the script files.
+#
+# Do not list $command_directory in this file, or it will be blown
+# away by a future Postfix uninstallation procedure. You would not
+# want to lose all files in /usr/sbin.
+#
+# Each record in this file describes one file or directory.
+# Fields are separated by ":". Specify a null field as "-".
+# Missing fields or separators at the end are OK.
+#
+# File format:
+# name:type:owner:group:permission:flags
+# No group means don't change group ownership.
+#
+# File types:
+# d=directory
+# f=regular file
+# l=symlink to $sendmail_path
+#
+# File flags:
+# No flag means the flag is not active.
+# p=preserve existing file, do not replace (postfix-install).
+# u=update owner/group/mode (post-install upgrade-permissions).
+# c=create missing directory (post-install create-missing).
+#
+# Note: the "u" flag is for upgrading the permissions of existing files
+# or directories after changes in Postfix architecture.
+#
+$config_directory:d:root:-:755:u
+$daemon_directory:d:root:-:755:u
+$queue_directory:d:root:-:755:uc
+$queue_directory/active:d:$mail_owner:-:700:uc
+$queue_directory/bounce:d:$mail_owner:-:700:uc
+$queue_directory/corrupt:d:$mail_owner:-:700:uc
+$queue_directory/defer:d:$mail_owner:-:700:uc
+$queue_directory/deferred:d:$mail_owner:-:700:uc
+$queue_directory/flush:d:$mail_owner:-:700:uc
+$queue_directory/incoming:d:$mail_owner:-:700:uc
+$queue_directory/private:d:$mail_owner:-:700:uc
+$queue_directory/saved:d:$mail_owner:-:700:uc
+$queue_directory/maildrop:d:$mail_owner:$setgid_group:730:uc
+$queue_directory/public:d:$mail_owner:$setgid_group:710:uc
+$queue_directory/pid:d:root:-:755:uc
+$daemon_directory/bounce:f:root:-:755
+$daemon_directory/cleanup:f:root:-:755
+$daemon_directory/error:f:root:-:755
+$daemon_directory/flush:f:root:-:755
+$daemon_directory/lmtp:f:root:-:755
+$daemon_directory/local:f:root:-:755
+$daemon_directory/master:f:root:-:755
+$daemon_directory/nqmgr:f:root:-:755
+$daemon_directory/pickup:f:root:-:755
+$daemon_directory/pipe:f:root:-:755
+$daemon_directory/qmgr:f:root:-:755
+$daemon_directory/qmqpd:f:root:-:755
+$daemon_directory/showq:f:root:-:755
+$daemon_directory/smtp:f:root:-:755
+$daemon_directory/smtpd:f:root:-:755
+$daemon_directory/spawn:f:root:-:755
+$daemon_directory/trivial-rewrite:f:root:-:755
+$daemon_directory/virtual:f:root:-:755
+$command_directory/postalias:f:root:-:755
+$command_directory/postcat:f:root:-:755
+$command_directory/postconf:f:root:-:755
+$command_directory/postfix:f:root:-:755
+$command_directory/postkick:f:root:-:755
+$command_directory/postlock:f:root:-:755
+$command_directory/postlog:f:root:-:755
+$command_directory/postmap:f:root:-:755
+$command_directory/postsuper:f:root:-:755
+$command_directory/postdrop:f:root:$setgid_group:2755
+$command_directory/postqueue:f:root:$setgid_group:2755
+$sendmail_path:f:root:-:755
+$newaliases_path:l:root:-:755
+$mailq_path:l:root:-:755
+$config_directory/LICENSE:f:root:-:644
+$config_directory/access:f:root:-:644:p
+$config_directory/aliases:f:root:-:644:p
+$config_directory/canonical:f:root:-:644:p
+$config_directory/main.cf:f:root:-:644:p
+$config_directory/main.cf.default:f:root:-:644
+$config_directory/master.cf:f:root:-:644:p
+$config_directory/pcre_table:f:root:-:644:p
+$config_directory/postfix-files:f:root:-:644
+$config_directory/regexp_table:f:root:-:644:p
+$config_directory/relocated:f:root:-:644:p
+$config_directory/sample-aliases.cf:f:root:-:644
+$config_directory/sample-auth.cf:f:root:-:644
+$config_directory/sample-canonical.cf:f:root:-:644
+$config_directory/sample-compatibility.cf:f:root:-:644
+$config_directory/sample-debug.cf:f:root:-:644
+$config_directory/sample-filter.cf:f:root:-:644
+$config_directory/sample-flush.cf:f:root:-:644
+$config_directory/sample-ldap.cf:f:root:-:644
+$config_directory/sample-lmtp.cf:f:root:-:644
+$config_directory/sample-local.cf:f:root:-:644
+$config_directory/sample-misc.cf:f:root:-:644
+$config_directory/sample-pcre-access.cf:f:root:-:644
+$config_directory/sample-pcre-body.cf:f:root:-:644
+$config_directory/sample-pcre-header.cf:f:root:-:644
+$config_directory/sample-qmqpd.cf:f:root:-:644
+$config_directory/sample-rate.cf:f:root:-:644
+$config_directory/sample-regexp-access.cf:f:root:-:644
+$config_directory/sample-regexp-body.cf:f:root:-:644
+$config_directory/sample-regexp-header.cf:f:root:-:644
+$config_directory/sample-relocated.cf:f:root:-:644
+$config_directory/sample-resource.cf:f:root:-:644
+$config_directory/sample-rewrite.cf:f:root:-:644
+$config_directory/sample-smtp.cf:f:root:-:644
+$config_directory/sample-smtpd.cf:f:root:-:644
+$config_directory/sample-transport.cf:f:root:-:644
+$config_directory/sample-virtual.cf:f:root:-:644
+$config_directory/transport:f:root:-:644:p
+$config_directory/virtual:f:root:-:644:p
+$config_directory/postfix-script:f:root:-:755
+$config_directory/post-install:f:root:-:755
+$manpage_path/man1/mailq.1:f:root:-:644
+$manpage_path/man1/newaliases.1:f:root:-:644
+$manpage_path/man1/postalias.1:f:root:-:644
+$manpage_path/man1/postcat.1:f:root:-:644
+$manpage_path/man1/postconf.1:f:root:-:644
+$manpage_path/man1/postdrop.1:f:root:-:644
+$manpage_path/man1/postfix.1:f:root:-:644
+$manpage_path/man1/postkick.1:f:root:-:644
+$manpage_path/man1/postlock.1:f:root:-:644
+$manpage_path/man1/postlog.1:f:root:-:644
+$manpage_path/man1/postmap.1:f:root:-:644
+$manpage_path/man1/postqueue.1:f:root:-:644
+$manpage_path/man1/postsuper.1:f:root:-:644
+$manpage_path/man1/sendmail.1:f:root:-:644
+$manpage_path/man5/access.5:f:root:-:644
+$manpage_path/man5/aliases.5:f:root:-:644
+$manpage_path/man5/canonical.5:f:root:-:644
+$manpage_path/man5/pcre_table.5:f:root:-:644
+$manpage_path/man5/regexp_table.5:f:root:-:644
+$manpage_path/man5/relocated.5:f:root:-:644
+$manpage_path/man5/transport.5:f:root:-:644
+$manpage_path/man5/virtual.5:f:root:-:644
+$manpage_path/man8/bounce.8:f:root:-:644
+$manpage_path/man8/cleanup.8:f:root:-:644
+$manpage_path/man8/defer.8:f:root:-:644
+$manpage_path/man8/error.8:f:root:-:644
+$manpage_path/man8/flush.8:f:root:-:644
+$manpage_path/man8/lmtp.8:f:root:-:644
+$manpage_path/man8/local.8:f:root:-:644
+$manpage_path/man8/master.8:f:root:-:644
+$manpage_path/man8/nqmgr.8:f:root:-:644
+$manpage_path/man8/pickup.8:f:root:-:644
+$manpage_path/man8/pipe.8:f:root:-:644
+$manpage_path/man8/qmgr.8:f:root:-:644
+$manpage_path/man8/qmqpd.8:f:root:-:644
+$manpage_path/man8/showq.8:f:root:-:644
+$manpage_path/man8/smtp.8:f:root:-:644
+$manpage_path/man8/smtpd.8:f:root:-:644
+$manpage_path/man8/spawn.8:f:root:-:644
+$manpage_path/man8/trivial-rewrite.8:f:root:-:644
+$manpage_path/man8/virtual.8:f:root:-:644
# SUMMARY
# Postfix installation procedure
# SYNOPSIS
-# sh postfix-install [-non-interactive] [name=value] ...
+# sh postfix-install [options] [name=value] ...
# DESCRIPTION
# The postfix-install script is to be run from the top-level
# Postfix source directory. It implements the following operations:
# .IP o
-# Install or upgrade Postfix from source code. This mode requires
+# Install or upgrade Postfix from source code. This requires
# super-user privileges.
# .IP o
# Build a package that can be distributed to other systems, in order
# Specific parameters are described at the end of this document.
#
# By default, postfix-install asks the user for installation
-# parameter settings. Settings are stored in the installed
-# main.cf file. These settings are used as site-specific defaults
+# parameter settings. Most settings are stored in the installed
+# main.cf file. Stored settings are used as site-specific defaults
# when the postfix-install script is run later.
#
# The names of Postfix files and directories, as well as their
#
# Arguments
# .IP -non-interactive
-# Do not ask the user for parameter settings. This is useful for
-# upgrading an existing Postfix installation from source code,
-# or for preparing a pre-built package for distribution to other
-# systems. Installation parameters must be specified via one of
-# the non-interactive methods described below.
+# Do not ask the user for parameter settings. Installation parameters
+# are specified via one of the non-interactive methods described
+# below.
# INSTALLATION PARAMETER INPUT METHODS
# .ad
# .fi
# Parameter settings can be specified through a variety of
# mechanisms. In order of decreasing precedence these are:
# .IP "interactive mode"
-# By default, postfix-install will ask the user for
-# installation parameter settings. These settings have the highest
-# precedence.
+# By default, postfix-install will ask the user for installation
+# parameter settings. These settings have the highest precedence.
# .IP "command line"
# Parameter settings can be given as name=value arguments on
# the postfix-install command line.
# Prefix that is prepended to the pathnames of installed files.
# This is useful for creating a pre-built package for distribution to
# other systems. The built-in default is "/", the local root directory.
+# This parameter setting is not recorded in the installed main.cf file.
# .IP tempdir
# Directory for scratch files while installing Postfix.
# You must must have write permission in this directory.
# The built-in default directory name is the current directory.
+# This parameter setting is not recorded in the installed main.cf file.
# .IP config_directory
-# Destination directory for Postfix configuration files. The
-# built-in default directory name is /etc/postfix.
+# The destination directory for Postfix configuration files.
+# The built-in default directory name is /etc/postfix.
+# This parameter setting is not recorded in the installed main.cf file.
# .IP daemon_directory
-# Destination directory for Postfix daemon programs. This directory
-# should not be in the command search path of any users. The built-in
-# default directory name is /usr/libexec/postfix.
+# The destination directory for Postfix daemon programs. This directory
+# should not be in the command search path of any users.
+# The built-in default directory name is /usr/libexec/postfix.
# .IP command_directory
-# Destination directory for Postfix administrative commands. This
+# The destination directory for Postfix administrative commands. This
# directory should be in the command search path of adminstrative users.
# The built-in default directory name is system dependent.
+# This parameter setting is recorded in the installed main.cf file.
# .IP queue_directory
-# The destination directory for Postfix queues. The built-in default
-# directory name is /var/spool/postfix.
+# The destination directory for Postfix queues.
+# The built-in default directory name is /var/spool/postfix.
+# This parameter setting is recorded in the installed main.cf file.
# .IP sendmail_path
# The full destination pathname for the Postfix sendmail command.
# This is the Sendmail-compatible mail posting interface.
# The built-in default pathname is system dependent.
+# This parameter setting is recorded in the installed main.cf file.
# .IP newaliases_path
# The full destination pathname for the Postfix newaliases command.
# This is the Sendmail-compatible command to build alias databases
# for the Postfix local delivery agent.
# The built-in default pathname is system dependent.
+# This parameter setting is recorded in the installed main.cf file.
# .IP mailq_path
# The full destination pathname for the Postfix mailq command.
# This is the Sendmail-compatible command to list the mail queue.
# The built-in default pathname is system dependent.
+# This parameter setting is recorded in the installed main.cf file.
# .IP mail_owner
# The owner of the Postfix queue. Its numerical user ID and group ID
-# must not be used by any other accounts on the system. The built-in
-# default account name is postfix.
+# must not be used by any other accounts on the system.
+# The built-in default account name is postfix.
+# This parameter setting is recorded in the installed main.cf file.
# .IP setgid_group
# The group for mail submission and for queue management commands.
# Its numerical group ID must not be used by any other accounts on the
-# system, not even by the mail_owner account. The built-in default group
-# name is postdrop.
+# system, not even by the mail_owner account.
+# The built-in default group name is postdrop.
+# This parameter setting is recorded in the installed main.cf file.
# .IP manpage_path
# The destination directory for the Postfix on-line manual pages.
+# This parameter setting is recorded in the installed main.cf file.
# SEE ALSO
# post-install(1) post-installation procedure
# FILES
# $config_directory/main.cf, Postfix installation configuration.
-# $config_directory/postfix-files, permissions and ownerships.
-# This file is created by postfix-install.
+# $config_directory/postfix-files, installation control file.
+# $config_directory/install.cf, obsolete configuration file.
# LICENSE
# .ad
# .fi
-# The Secure Mailer license must be distributed with this software.
+# The Secure Mailer license must be distributed with this software.
# AUTHOR(S)
-# Wietse Venema
-# IBM T.J. Watson Research
-# P.O. Box 704
-# Yorktown Heights, NY 10598, USA
+# Wietse Venema
+# IBM T.J. Watson Research
+# P.O. Box 704
+# Yorktown Heights, NY 10598, USA
#--
# Initialize.
SHELL=/bin/sh
IFS="
"
+BACKUP_IFS="$IFS"
+
+USAGE="Usage: $0 [name=value] [option]
+ -non-interactive Do not ask for installation parameters.
+ name=value Specify an installation parameter".
# Process command-line options and parameter settings. Work around
-# brain damaged shells. "name=value command" should not make the
-# name=value setting permanent.
+# brain damaged shells. "IFS=value command" should not make the
+# IFS=value setting permanent. But some broken standard allows it.
for arg
do
case $arg in
- *=*) SAVED_IFS="$IFS"; IFS= eval $arg; IFS="$SAVED_IFS";;
--non-interactive) non_interactive=1;;
- *) echo Error: usage: $0 [-non-interactive] name=value ... 1>&2
- exit 1;;
+ *=*) IFS= eval $arg; IFS="$BACKUP_IFS";;
+-non-int*) non_interactive=1;;
+ *) echo $0: Error: $USAGE 1>&2; exit 1;;
esac
shift
done
# Sanity checks.
test -z "$non_interactive" -a ! -t 0 && {
- echo Error: for non-interactive use, run: \"$0 -non-interactive\" 1>&2
+ echo $0: Error: for non-interactive use, run: \"$0 -non-interactive\" 1>&2
exit 1
}
test -x bin/postconf || {
- echo Error: no bin/postconf file. Did you forget to run \"make\"? 1>&2
+ echo $0: Error: no bin/postconf file. Did you forget to run \"make\"? 1>&2
exit 1
}
# when upgrading Postfix on a live machine. It also avoids surprises
# when building a Postfix package for distribution to other systems.
-censored_ls() {
- ls "$@" | egrep -v '^\.|/\.|CVS|RCS|SCCS'
-}
-
compare_or_replace() {
- (cmp $2 $3 >/dev/null 2>&1 && echo Skipping $3...) || {
- echo Updating $3...
+ mode=$1
+ owner=$2
+ group=$3
+ src=$4
+ dst=$5
+ (cmp $src $dst >/dev/null 2>&1 && echo Skipping $dst...) || {
+ echo Updating $dst...
rm -f $tempdir/junk || exit 1
- cp $2 $tempdir/junk || exit 1
- test -z "$4" || chgrp $4 $tempdir/junk || exit 1
- chmod $1 $tempdir/junk || exit 1
- mv -f $tempdir/junk $3 || exit 1
- test -z "$4" || chgrp $4 $3 || exit 1
- chmod $1 $3 || exit 1
+ cp $src $tempdir/junk || exit 1
+ mv -f $tempdir/junk $dst || exit 1
+ test -z "$owner" || chown $owner $dst || exit 1
+ test -z "$group" || chgrp $group $dst || exit 1
+ chmod $mode $dst || exit 1
}
}
'`
ln -s $link $tempdir/junk || exit 1
mv -f $tempdir/junk $2 || {
- echo Error: your mv command is unable to rename symlinks. 1>&2
+ echo $0: Error: your mv command is unable to rename symlinks. 1>&2
echo If you run Linux, upgrade to GNU fileutils-4.0 or better, 1>&2
echo or choose a tempdir that is in the same file system as $2. 1>&2
exit 1
}
}
-compare_or_move() {
- (cmp $2 $3 >/dev/null 2>&1 && echo Skipping $3...) || {
- echo Updating $3...
- mv -f $2 $3 || exit 1
- chmod $1 $3 || exit 1
- }
+check_parent() {
+ for path
+ do
+ dir=`echo $path|sed -e 's/[/][/]*[^/]*$//' -e 's/^$/\//'`
+ test -d $dir || mkdir -p $dir || exit 1
+ done
}
# How to supress newlines in echo.
case $ans in
"") break;;
*) case $ans in
- /*) eval $name=\$ans; break;;
- *) echo; echo Error: $name should be an absolute path name. 1>&2;;
+ /*) eval $name=$ans; break;;
+ *) echo; echo $0: Error: $name should be an absolute path name. 1>&2;;
esac;;
esac
done
# If a parameter is not set via the command line or environment,
# try to use settings from installed configuration files.
-# Extract parameter settings from the installed main.cf file.
-
-test -f $CONFIG_DIRECTORY/main.cf && {
- for name in daemon_directory command_directory queue_directory mail_owner \
- setgid_group sendmail_path newaliases_path mailq_path manpage_path
- do
- eval : \${$name=\`bin/postconf -c $CONFIG_DIRECTORY -h $name\`} || kill $$
- done
-}
-
-# Grandfathering: some parameters used to be stored in install.cf.
-# They are now part of main.cf. Some names have changed as well.
+# Extract parameter settings from the obsolete install.cf file, as
+# a transitional aid.
grep setgid_group $CONFIG_DIRECTORY/main.cf >/dev/null 2>&1 || {
- test -f $CONFIG_DIRECTORY/install.cf && {
+ test -f $CONFIG_DIRECTORY/install.cf && {
for name in sendmail_path newaliases_path mailq_path setgid manpages
do
- eval : \${$name=`. $CONFIG_DIRECTORY/install.cf; echo \$name`}
+ eval : \${$name="\`. $CONFIG_DIRECTORY/install.cf; echo \$$name\`"} \
+ || exit 1
done
: ${setgid_group=$setgid}
: ${manpage_path=$manpages}
}
}
-# Find out what parameters were not specified via command line,
-# via environment, or via installed configuration files.
-
-missing=
-for name in daemon_directory command_directory queue_directory mail_owner \
- setgid_group sendmail_path newaliases_path mailq_path manpage_path
-do
- eval test -n \"\$$name\" || missing="$missing $name"
-done
-
-# In the case of non-interactive installation, all parameters must
-# be specified at this point.
-
-test -n "$non_interactive" -a -n "$missing" && {
- cat <<EOF | ${FMT} 1>&2
-Error: non-interactive installation requires that all parameters
-be specified ahead of time.
-
-- Either the parameters must be given in the $CONFIG_DIRECTORY/main.cf
-file from a recent Postfix installation,
-
-- Or the parameters need to be specified as name=value arguments
-on the $0 command line,
-
-- Or the parameters need to be specified through the process
-environment.
-
-The following parameters were missing:
-
- $missing
+# Extract parameter settings from the installed main.cf file.
-For interactive installation use "make install".
-EOF
- exit 1
+test -f $CONFIG_DIRECTORY/main.cf && {
+ for name in daemon_directory command_directory queue_directory mail_owner \
+ setgid_group sendmail_path newaliases_path mailq_path manpage_path
+ do
+ eval : \${$name=\`bin/postconf -c $CONFIG_DIRECTORY -h $name\`} ||
+ exit 1
+ done
}
-# Use built-in defaults for parameters that weren't set via the
-# environment, via the command line, or via installed configuration
-# files.
+# Use built-in defaults as the final source of parameter settings.
-for name in $missing
+for name in daemon_directory command_directory queue_directory mail_owner \
+ setgid_group sendmail_path newaliases_path mailq_path manpage_path
do
- eval : \${$name=\`bin/postconf -d -h $name\`} || kill $$
+ eval : \${$name=\`bin/postconf -d -h $name\`} || exit 1
done
-# Override default settings.
+# Override settings manually.
test -z "$non_interactive" && for name in daemon_directory command_directory \
queue_directory sendmail_path newaliases_path mailq_path mail_owner \
read ans
case $ans in
"") break;;
- *) eval $name=\$ans; break;;
+ *) eval $name=$ans; break;;
esac
done
done
# Sanity checks
-case $manpage_path in
- no) echo Error: manpage_path no longer accepts \"no\" values. 1>&2
- echo Re-run this script with \"make install\". 1>&2; exit 1;;
+case $setgid_group in
+ no) echo $0: Error: the setgid_group parameter no longer accepts 1>&2
+ echo \"no\" values. Try again with \"setgid_group=groupname\" on the 1>&2
+ echo command line or execute \"make install\" and specify setgid_group 1>&2
+ echo interactively. 1>&2
+ exit 1;;
esac
-case $setgid_group in
- no) echo Error: setgid_group no longer accepts \"no\" values. 1>&2
- echo Re-run this script with \"make install\". 1>&2; exit 1;;
+case $manpage_path in
+ no) echo $0: Error: the manpage_path parameter no longer accepts 1>&2
+ echo \"no\" values. Try again with \"manpage_path=/path/name\" on the 1>&2
+ echo command line or execute \"make install\" and specify manpage_path 1>&2
+ echo interactively. 1>&2
+ exit 1;;
esac
for path in $daemon_directory $command_directory \
do
case $path in
/*) ;;
- *) echo Error: $path should be an absolute path name. 1>&2; exit 1;;
+ *) echo $0: Error: $path should be an absolute path name. 1>&2; exit 1;;
esac
done
test -d $tempdir || mkdir -p $tempdir || exit 1
+trap "rm -f $tempdir/junk" 0 1 2 3 15
+
( rm -f $tempdir/junk && touch $tempdir/junk ) || {
- echo Error: you have no write permission to $tempdir. 1>&2
+ echo $0: Error: you have no write permission to $tempdir. 1>&2
echo Specify an alternative directory for scratch files. 1>&2
exit 1
}
-rm -f $tempdir/junk
+test -z "$install_root" && {
+
+ chown root $tempdir/junk >/dev/null 2>&1 || {
+ echo Error: you have no permission to change file ownership. 1>&2
+ exit 1
+ }
+
+ chown "$mail_owner" $tempdir/junk >/dev/null 2>&1 || {
+ echo $0: Error: $mail_owner needs an entry in the passwd file. 1>&2
+ echo Remember, $mail_owner needs a dedicated user id and group id. 1>&2
+ exit 1
+ }
+
+ chgrp "$setgid_group" $tempdir/junk >/dev/null 2>&1 || {
+ echo $0: Error: $setgid needs an entry in the group file. 1>&2
+ echo Remember, $setgid needs a dedicated group id. 1>&2
+ exit 1
+ }
+
+}
+
+rm -f $tempdir/junk || exit 1
+
+trap 0 1 2 3 15
# Avoid clumsiness.
MAILQ_PATH=$install_root$mailq_path
MANPAGE_PATH=$install_root$manpage_path
-# Create any missing directories.
+# Avoid repeated tests for existence of these.
-test -d $CONFIG_DIRECTORY || mkdir -p $CONFIG_DIRECTORY || exit 1
test -d $DAEMON_DIRECTORY || mkdir -p $DAEMON_DIRECTORY || exit 1
test -d $COMMAND_DIRECTORY || mkdir -p $COMMAND_DIRECTORY || exit 1
-test -d $QUEUE_DIRECTORY || mkdir -p $QUEUE_DIRECTORY || exit 1
-for path in $SENDMAIL_PATH $NEWALIASES_PATH $MAILQ_PATH
-do
- dir=`echo $path|sed -e 's/[/][/]*[^/]*$//' -e 's/^$/\//'`
- test -d $dir || mkdir -p $dir || exit 1
-done
-# Install files. Keep a record of pathnames, ownerships and permissions
-# so that "postfix check" and "post-install" can do the right thing.
+# Upgrade or first-time installation?
-# If building a package for distribution to other systems, don't
-# enable execute permission.
-
-if [ -n "$install_root" ]
+if [ -f $CONFIG_DIRECTORY/main.cf ]
then
- EXE=644
+ post_install_options="upgrade-source"
else
- EXE=755
+ post_install_options="first-install"
fi
-cat <<EOF >$CONFIG_DIRECTORY/postfix-files || exit 1
-#
-# Do not edit. This file was generated by $0.
-#
-# Do not list \$command_directory here, or it will be blown
-# away by a future Postfix uninstallation procedure.
-#
-# File format:
-# name:type:owner:group:permission:upgrade:create
-# No group means don't change group ownership.
-#
-# File flags:
-# No flag means the flag is not active.
-# update=update owner/group/mode (upgrade mode).
-# create=create missing directory.
-#
-\$config_directory:d:root::755:u
-\$daemon_directory:d:root::755:u
-\$queue_directory:d:root::755:u:c
-EOF
-
-# Generate instructions only for queue subdirectories.
+# Install files, using information from the postfix-files file.
-for dir in active bounce corrupt defer deferred flush incoming private saved
+exec < conf/postfix-files || exit 1
+while IFS=: read path type owner group mode flags junk
do
- echo \$queue_directory/$dir:d:\$mail_owner::700:u:c \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-done
-
-echo \$queue_directory/maildrop:d:\$mail_owner:\$setgid_group:730:u:c \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-
-echo \$queue_directory/public:d:\$mail_owner:\$setgid_group:710:u:c \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-
-echo \$queue_directory/pid:d:root::755:u:c \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
+ IFS="$BACKUP_IFS"
-# Install daemon programs.
+ # Skip comments.
-for file in `censored_ls libexec`
-do
- compare_or_replace $EXE libexec/$file $DAEMON_DIRECTORY/$file || exit 1
- echo \$daemon_directory/$file:f:root::755 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-done
+ case $path in
+ [$]*) ;;
+ *) continue;;
+ esac
-# Install administrative commands.
+ # Skip over files that must be preserved.
-for file in `censored_ls bin | grep '^post' | egrep -v '^post(drop|queue)$'`
-do
- compare_or_replace $EXE bin/$file $COMMAND_DIRECTORY/$file || exit 1
- echo \$command_directory/$file:f:root::755 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-done
+ case $flags in
+ *p*) eval test -f $install_root$path && {
+ eval echo "Skipping $install_root$path..."
+ continue
+ };;
+ esac
-# Don't set privilege bits when building a package for distribution
-# to other systems.
+ # If installing from source code, apply special permissions or ownership.
+ # If building a package, don't apply special permissions or ownership.
-if [ -n "$install_root" ]
-then
- for file in postdrop postqueue
- do
- compare_or_replace $EXE bin/$file $COMMAND_DIRECTORY/$file || exit 1
- echo \$command_directory/$file:f:root:\$setgid_group:2755 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
- done
-else
- for file in postdrop postqueue
- do
- compare_or_replace 2$EXE bin/$file $COMMAND_DIRECTORY/$file postdrop \
- || exit 1
- echo \$command_directory/$file:f:root:\$setgid_group:2755 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
- done
-fi
+ case $install_root in
+ "") case $owner in
+ [$]*) eval owner=$owner;;
+ root) owner=;;
+ esac
+ case $group in
+ [$]*) eval group=$group;;
+ -) group=;;
+ esac;;
+ *) case $mode in
+ [1-7]755) mode=755;;
+ esac
+ owner=
+ group=;;
+ esac
-# Install the Sendmail-compatible user interface.
+ # Create directory.
+
+ case $type in
+ d) eval path=$install_root$path
+ test -d $path || {
+ mkdir -p $path || exit 1
+ test -z "$owner" || chown $owner $path || exit 1
+ test -z "$group" || chgrp $group $path || exit 1
+ chmod $mode $path || exit 1
+ }
+ continue;;
+ [fl]) ;;
+ *) echo $0: Error: unknown type for $path in conf/postfix-files; exit 1;;
+ esac
-test -f bin/sendmail && {
- compare_or_replace $EXE bin/sendmail $SENDMAIL_PATH || exit 1
- compare_or_symlink $SENDMAIL_PATH $NEWALIASES_PATH
- compare_or_symlink $SENDMAIL_PATH $MAILQ_PATH
-cat <<EOF >>$CONFIG_DIRECTORY/postfix-files || exit 1
-\$sendmail_path:f:root::755
-\$newaliases_path:f:root::755
-\$mailq_path:f:root::755
-EOF
-}
+ # Install or replace file.
+
+ echo $path | (IFS=/ read prefix file; IFS="$BACKUP_IFS"
+ case $prefix in
+ '$daemon_directory')
+ compare_or_replace $mode "$owner" "$group" libexec/$file \
+ $DAEMON_DIRECTORY/$file || exit 1;;
+ '$command_directory')
+ compare_or_replace $mode "$owner" "$group" bin/$file \
+ $COMMAND_DIRECTORY/$file || exit 1;;
+ '$config_directory')
+ compare_or_replace $mode "$owner" "$group" conf/$file \
+ $CONFIG_DIRECTORY/$file || exit 1;;
+ '$sendmail_path')
+ check_parent $SENDMAIL_PATH || exit 1
+ compare_or_replace $mode "$owner" "$group" bin/sendmail \
+ $SENDMAIL_PATH || exit 1;;
+ '$mailq_path')
+ check_parent $MAILQ_PATH || exit 1
+ compare_or_symlink $SENDMAIL_PATH $MAILQ_PATH || exit 1;;
+ '$newaliases_path')
+ check_parent $NEWALIASES_PATH || exit 1
+ compare_or_symlink $SENDMAIL_PATH $NEWALIASES_PATH || exit 1;;
+ '$manpage_path')
+ check_parent $MANPAGE_PATH/$file || exit 1
+ compare_or_replace 644 "$owner" "$group" man/$file \
+ $MANPAGE_PATH/$file || exit 1;;
+ *) echo $0: Error: unknown entry $path in conf/postfix-files; exit 1;;
+ esac) || exit 1
+done
-# Preserve installed configuration files. Update scripts, license, samples.
+# If Postfix is being installed locally from source code, do the
+# post-install processing now. The post-install script will update
+# main.cf with actual installaton parameter settings.
+#
+# If Postfix is being packaged for distribution to other systems,
+# save the installation parameters to main.cf so they can be used
+# as default settings when the post-install script is executed.
-if [ -f $CONFIG_DIRECTORY/main.cf ]
+if [ -z "$install_root" ]
then
- for file in LICENSE `cd conf; censored_ls sample*` main.cf.default
- do
- compare_or_replace 644 conf/$file $CONFIG_DIRECTORY/$file || exit 1
- done
+ export daemon_directory command_directory queue_directory mail_owner \
+ setgid_group sendmail_path newaliases_path mailq_path manpage_path
+ ${SHELL} conf/post-install $post_install_options || exit 1
else
- for file in `censored_ls conf | egrep -v '^(postfix-script|post-install)$'`
- do
- compare_or_replace 644 conf/$file $CONFIG_DIRECTORY/$file || exit 1
- done
- test -z "$install_root" && need_config="create-missing first-install"
+ bin/postconf -c $CONFIG_DIRECTORY -e \
+ "daemon_directory = $daemon_directory" \
+ "command_directory = $command_directory" \
+ "queue_directory = $queue_directory" \
+ "mail_owner = $mail_owner" \
+ "setgid_group = $setgid_group" \
+ "sendmail_path = $sendmail_path" \
+ "mailq_path = $mailq_path" \
+ "newaliases_path = $newaliases_path" \
+ "manpage_path = $manpage_path" \
+ || exit 1
fi
-
-for file in `censored_ls conf | egrep -v 'postfix-script|post-install'`
-do
- echo \$config_directory/$file:f:root::644 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-done
-
-for file in postfix-script post-install
-do
- compare_or_replace $EXE conf/$file $CONFIG_DIRECTORY/$file || exit 1
- echo \$config_directory/$file:f:root::755 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
-done
-
-# Save settings.
-
-bin/postconf -c $CONFIG_DIRECTORY -e \
- "daemon_directory = $daemon_directory" \
- "command_directory = $command_directory" \
- "queue_directory = $queue_directory" \
- "mail_owner = $mail_owner" \
- "setgid_group = $setgid_group" \
- "sendmail_path = $sendmail_path" \
- "mailq_path = $mailq_path" \
- "newaliases_path = $newaliases_path" \
- "manpage_path = $manpage_path" \
-|| exit 1
-
-# Install manual pages.
-
-(cd man || exit 1
- for dir in man?
- do test -d $MANPAGE_PATH/$dir || mkdir -p $MANPAGE_PATH/$dir || exit 1
- done
- for file in `censored_ls man?/*`
- do
- compare_or_replace 644 $file $MANPAGE_PATH/$file || exit 1
- echo \$manpage_path/$file:f:root::644 \
- >>$CONFIG_DIRECTORY/postfix-files || exit 1
- done)
-
-# If Postfix is being installed locally from source code, as opposed to
-# being packaged for distribution to other systems, do the post-install
-# processing now.
-
-test -n "$install_root" && exit 0
-
-export command_directory config_directory
-
-${SHELL} conf/post-install ${need_config-"upgrade-source"}
* Version of this program.
*/
#define VAR_MAIL_VERSION "mail_version"
-#define DEF_MAIL_VERSION "Snapshot-20020112"
+#define DEF_MAIL_VERSION "Snapshot-20020113"
extern char *var_mail_version;
/* LICENSE
#define STRING_FORMAT "%-10s %8s %-20s %s\n"
#define DATA_FORMAT "%-10s%c%8ld %20.20s %s\n"
-#define DROP_FORMAT "%-10s%c%8ld %20.20s (maildrop queue, sender UID %d)\n"
+#define DROP_FORMAT "%-10s%c%8ld %20.20s (maildrop queue, sender UID %u)\n"
static void showq_reasons(VSTREAM *, BOUNCE_LOG *, HTABLE *);
vstream_fprintf(client, DROP_FORMAT, id, ' ',
(long) st.st_size,
asctime(localtime(&st.st_mtime)),
- st.st_uid);
+ (unsigned) st.st_uid);
} else if (errno != ENOENT)
msg_fatal("open %s %s: %m", qp->name, id);
file_count++;
usr_attr.gid = (gid_t) n;
if (msg_verbose)
- msg_info("%s[%d]: set user_attr: %s, uid = %d, gid = %d",
- myname, state.level,
- usr_attr.mailbox, usr_attr.uid, usr_attr.gid);
+ msg_info("%s[%d]: set user_attr: %s, uid = %u, gid = %u",
+ myname, state.level, usr_attr.mailbox,
+ (unsigned) usr_attr.uid, (unsigned) usr_attr.gid);
/*
* Deliver to mailbox or to external command.